# **TOSHIBA**

**TOSHIBA Original CMOS 16-Bit Microcontroller** 

# TLCS-900/L1 Series

TMP91C820A

# **TOSHIBA CORPORATION**

Semiconductor Company

# **Preface**

Thank you very much for making use of Toshiba microcomputer LSIs. Before use this LSI, refer the section, "Points of Note and Restrictions". Especially, take care below cautions.

# \*\*CAUTION\*\* How to release the HALT mode

Usually, interrupts can release all halts status. However, the interrupts =  $(\overline{\text{NMI}}, \text{INT0 to INT3}, \text{INTRTC}, \text{INTALM0 to INTALM4}, \text{INTKEY})$ , which can release the HALT mode may not be able to do so if they are input during the period CPU is shifting to the HALT mode (for about 5 clocks of  $f_{\text{FPH}}$ ) with IDLE1 or STOP mode (IDLE2 is not applicable to this case). (In this case, an interrupt request is kept on hold internally.)

If another interrupt is generated after it has shifted to HALT mode completely, halt status can be released without difficultly. The priority of this interrupt is compare with that of the interrupt kept on hold internally, and the interrupt with higher priority is handled first followed by the other interrupt.

# CMOS 16-Bit Microcontrollers TMP91C820AF/JT5AW4-S

#### Outline and Features

TMP91C820A/JT5AW4 is a high-speed 16-bit microcontroller designed for the control of various mid- to large-scale equipment.

TMP91C820AF comes in a 144-pin flat package. JT5AW4-S comes in a 144-pad chip.

Listed below are the features.

(1) High-speed 16-bit CPU (900/L1 CPU)

Instruction mnemonics are upward compatible with TLCS-90

16 Mbytes of linear address space

General-purpose registers and register banks

16-bit multiplication and division instructions; bit transfer and arithmetic instructions

Micro DMA: 4 channels (444 ns/2 bytes at 36 MHz)

(2) Minimum instruction execution time: 111ns (at 36 MHz)

(3) Built-in RAM: 8 Kbytes

Built-in ROM: 8 Kbytes (However, 9999 (ROM code) has no internal ROM.)

#### **RESTRICTIONS ON PRODUCT USE**

060116EBP

- The information contained herein is subject to change without notice. 021023\_D
- TOSHIBA is continually working to improve the quality and reliability of its products. Nevertheless, semiconductor
  devices in general can malfunction or fail due to their inherent electrical sensitivity and vulnerability to physical
  stress. It is the responsibility of the buyer, when utilizing TOSHIBA products, to comply with the standards of safety
  in making a safe design for the entire system, and to avoid situations in which a malfunction or failure of such
  TOSHIBA products could cause loss of human life, bodily injury or damage to property.
  - In developing your designs, please ensure that TOSHIBA products are used within specified operating ranges as set forth in the most recent TOSHIBA products specifications. Also, please keep in mind the precautions and conditions set forth in the "Handling Guide for Semiconductor Devices," or "TOSHIBA Semiconductor Reliability Handbook" etc. 021023\_A
- The TOSHIBA products listed in this document are intended for usage in general electronics applications (computer, personal equipment, office equipment, measuring equipment, industrial robotics, domestic appliances, etc.). These TOSHIBA products are neither intended nor warranted for usage in equipment that requires extraordinarily high quality and/or reliability or a malfunctionor failure of which may cause loss of human life or bodily injury ("Unintended Usage"). Unintended Usage include atomic energy control instruments, airplane or spaceship instruments, transportation instruments, traffic signal instruments, combustion control instruments, medical instruments, all types of safety devices, etc. Unintended Usage of TOSHIBA products listed in this document shall be made at the customer's own risk. 021023\_B
- The products described in this document shall not be used or embedded to any downstream products of which
  manufacture, use and/or sale are prohibited under any applicable laws and regulations. 060106\_Q
- The information contained herein is presented only as a guide for the applications of our products. No responsibility
  is assumed by TOSHIBA for any infringements of patents or other rights of the third parties which may result from
  its use. No license is granted by implication or otherwise under any patent or patent rights of TOSHIBA or others.
  021023\_C
- The products described in this document are subject to the foreign exchange and foreign trade laws. 021023\_E
- For a discussion of how the reliability of microcontrollers can be predicted, please refer to Section 1.3 of the chapter entitled Quality and Reliability Assurance/Handling Precautions. 030619\_s

- (4) External memory expansion
  - Expandable up to 136 Mbytes (Shared program/data area)
  - Can simultaneously support 8- or 16-bit width external data bus ... Dynamic data bus sizing
  - Separate bus system
- (5) 8-bit timers: 4 channels
- (6) 16-bit timer: 1 channel
- (7) General-purpose serial interface: 3 channels
  - UART/synchronous mode
  - IrDA
- (8) Serial bus interface: 1 channel

I<sup>2</sup>C bus mode/clock synchronous select mode

- (9) LCD controller
  - Shift register/built-in RAM LCD driver
  - Supported 16, 8 and 4 gray levels and black and white
  - Hardware blinking cursor
- (10) SDRAM controller

Supported 16-M, 64-M and 128-Mbit SDRAM with 16-bit data bus

- (11) Timer for real time clock (RTC)
  - Based on TC8521A
- (12) Key-on wakeup (Interrupt key input)
- (13) 10-bit AD converter: 8 channels
- (14) Watchdog timer
- (15) Melody/alarm generator
  - Melody: Output of clock 4 to 5461 Hz
  - Alarm: Output of the 8 kinds of alarm pattern
  - Output of the 5 kinds of interval interrupt
- (16) Chip select/wait controller: 4 channels
- (17) MMU
  - Expandable up to 136 Mbytes (4 local area/8-bank method)
- (18) Interrupts: 46 interrupts
  - 9 CPU interrupts: Software interrupt instruction and illegal instruction
  - 31 internal interrupts: Seven selectable priority levels
  - 6 external interrupts: Seven selectable priority levels (4-edge selectable)
- (19) Input/output ports: 77 pins (at external 16-bit data bus memory)
- (20) Standby function

Three HALT modes: IDLE2 (Programmable), IDLE1, STOP

(21) Hardware standby function (Power save function)

## (22) Triple-clock controller

Clock doubler (DFM)

Clock gear function: Select a high-frequency clock fc to fc/16  $\,$ 

RTC (fs = 32.768 kHz)

## (23) Operating voltage

- VCC = 2.7 V to 3.6 V (fc = 27 MHz)
- VCC = 3.0 V to 3.6 V (fc max = 36 MHz)

#### (24) Package

- 144-pin QFP: P-LQFP144-1616-0.40C
- Chip form supply also available. For details, contact your local Toshiba sales representative.



Note: When ROM code is 9999, it has no ROM.

Figure 1.1 TMP91C820A Block Diagram

# 2. Pin Assignment and Pin Functions

The assignment of input/output pins for the TMP91C820A, their names and functions are as follows:

# 2.1 Pin Assignment Diagram

Figure 2.1.1 shows the pin assignment of the TMP91C820AF.



Figure 2.1.1 Pin Assignment Diagram (144-pin QFP)

# 2.2 PAD layout

(Chip size 5.75 mm  $\times$  5.63 mm)

Unit: µm

| (Only on   | ze 5./5 mm × | 3.03 11111)    | 1             |            |       | 1                 | ī              |            | 1     | 1          | Unit: µm |
|------------|--------------|----------------|---------------|------------|-------|-------------------|----------------|------------|-------|------------|----------|
| PIN<br>No. | Name         | X Point        | Y Point       | PIN<br>No. | Name  | X Point           | Y Point        | PIN<br>No. | Name  | X Point    | Y Point  |
| 1          | P81          | -2742          | 2128          | 49         | XT2   | -485              | -2682          | 97         | P37   | 2736       | 758      |
| 2          | P82          | -2742<br>-2742 | 2004          | 50         | EMU0  | - <del>4</del> 03 | -2682          | 98         | DVCC2 | 2736       | 872      |
|            |              |                |               |            |       |                   | -2682          |            |       |            |          |
| 3          | P83          | -2742          | 1888          | 51         | EMU1  | -256              |                | 99         | P20   | 2736       | 986      |
| 4          | P84          | -2742          | 1774          | 52         | PD1   | -142              | -2682          | 100        | DVSS5 | 2736       | 1202     |
| 5          | P85          | -2742          | 1660          | 53         | PD2   | -28               | -2682          | 101        | P21   | 2736       | 1318     |
| 6          | P86          | -2742          | 1546          | 54         | PD3   | 86                | -2682          | 102        | P22   | 2736       | 1432     |
| 7          | P87          | -2742          | 1432          | 55         | PD4   | 200               | -2682          | 103        | P23   | 2736       | 1546     |
| 8          | AVSS         | -2742          | 1318          | 56         | PE0   | 314               | -2682          | 104        | P24   | 2736       | 1660     |
| 9          | AVCC         | -2742          | 1204          | 57         | PE1   | 428               | -2682          | 105        | P25   | 2736       | 1774     |
| 10         | P92          | -2742          | 892           | 58         | PE2   | 542               | -2682          | 106        | P26   | 2736       | 1888     |
| 11         | P93          | -2742          | 778           | 59         | PE3   | 656               | -2682          | 107        | P27   | 2736       | 2004     |
| 12         | P94          | -2742          | 664           | 60         | PE4   | 770               | -2682          | 108        | PZ0   | 2736       | 2128     |
| 13         | P95          | -2742          | 550           | 61         | PE5   | 884               | -2682          | 109        | PZ1   | 2188       | 2676     |
| 14         | P96          | -2742          | 436           | 62         | PE6   | 998               | -2682          | 110        | PZ2   | 2062       | 2676     |
| 15         | P97          | -2742          | 322           | 63         | PE7   | 1112              | -2682          | 111        | PZ3   | 1948       | 2676     |
| 16         | PA0          | -2742          | 208           | 64         | DVSS3 | 1246              | -2682          | 112        | P56   | 1834       | 2676     |
| 17         | PA1          | -2742          | 94            | 65         | P00   | 1378              | -2682          | 113        | P60   | 1720       | 2676     |
| 18         | PA2          | -2742          | -20           | 66         | P01   | 1492              | -2682          | 114        | P61   | 1606       | 2676     |
| 19         | PA3          | -2742          | -134          | 67         | P02   | 1606              | -2682          | 115        | P62   | 1492       | 2676     |
| 20         | PA4          | -2742          | -248          | 68         | P03   | 1720              | -2682          | 116        | DVSS6 | 1378       | 2676     |
| 21         | PA5          | -2742          | -362          | 69         | P04   | 1834              | -2682          | 117        | P63   | 1264       | 2676     |
| 22         | PA6          | -2742          | -476          | 70         | P05   | 1948              | -2682          | 118        | P64   | 1150       | 2676     |
| 23         | PA7          | -2742          | -590          | 71         | P06   | 2062              | -2682          | 119        | P65   | 1036       | 2676     |
| 24         | PB0          | -2742          | -704          | 72         | P07   | 2188              | -2682          | 120        | P66   | 922        | 2676     |
| 25         | PB1          | -2742          | -818          | 73         | P10   | 2736              | -2134          | 121        | P67   | 808        | 2676     |
| 26         | PB3          | -2742          | -932          | 74         | P11   | 2736              | -2010          | 122        | P70   | 694        | 2676     |
| 27         | PB4          | -2742          | -1046         | 75         | P12   | 2736              | -1894          | 123        | P71   | 580        | 2676     |
| 28         | DVSS1        | -2742          | -1210         | 76         | P13   | 2736              | -1780          | 124        | P72   | 382        | 2676     |
| 29         | PB5          | -2742<br>-2742 | -1324         | 77         | P14   | 2736              | -1766<br>-1666 | 125        | DVCC3 | 268        | 2676     |
| 30         | PB6          |                | -1438         | 78         | P15   | 2736              |                |            | P73   | 68         | 2676     |
|            |              | -2742          |               |            | P16   |                   | -1552<br>4439  | 126        |       |            |          |
| 31         | PC0          | -2742          | -1552         | 79         |       | 2736              | -1438          | 127        | P74   | -46<br>460 | 2676     |
| 32         | PC1          | -2742          | -1666         | 80         | DVSS4 | 2736              | -1318          | 128        | P75   | -160       | 2676     |
| 33         | PC2          | -2742          | -1780<br>4004 | 81         | P17   | 2736              | -1066          | 129        | P76   | -274       | 2676     |
| 34         | PC3          | -2742          | -1894         | 82         | P40   | 2736              | -952           | 130        | P77   | -388       | 2676     |
| 35         | PC4          | -2742          | -2010         | 83         | P41   | 2736              | -838           | 131        | PD6   | -520       | 2676     |
| 36         | PC5          | -2742          | -2134         | 84         | P42   | 2736              | -724           | 132        | PD7   | -634       | 2676     |
| 37         | PF0          | -2194          | -2682         | 85         | P43   | 2736              | -610           | 133        | PF3   | -748       | 2676     |
| 38         | PF1          | -2068          | -2682         | 86         | P44   | 2736              | -496           | 134        | PF4   | -862       | 2676     |
| 39         | PF2          | -1954          | -2682         | 87         | P45   | 2736              | -382           | 135        | PF5   | -976       | 2676     |
| 40         | PD0          | -1840          | -2682         | 88         | P46   | 2736              | -268           | 136        | DVSS7 | -1090      | 2676     |
| 41         | AM0          | -1726          | -2682         | 89         | P47   | 2736              | -154           | 137        | PF6   | -1204      | 2676     |
| 42         | DVCC1        | -1612          | -2682         | 90         | P30   | 2736              | -40            | 138        | PF7   | -1318      | 2676     |
| 43         | X2           | -1410          | -2682         | 91         | P31   | 2736              | 74             | 139        | P90   | -1432      | 2676     |
| 44         | DVSS2        | -1244          | -2682         | 92         | P32   | 2736              | 188            | 140        | P91   | -1546      | 2676     |
| 45         | X1           | -1079          | -2682         | 93         | P33   | 2736              | 302            | 141        | NMI   | -1660      | 2676     |
| 46         | AM1          | -963           | -2682         | 94         | P34   | 2736              | 416            | 142        | VREFL | -1954      | 2676     |
| 47         | RESET        | -849           | -2682         | 95         | P35   | 2736              | 530            | 143        | VREFH | -2068      | 2676     |
| 48         | XT1          | -734           | -2682         | 96         | P36   | 2736              | 644            | 144        | P80   | -2194      | 2676     |

# 2.3 Pin Names and Functions

The names of the input/output pins and their functions are described below.

Table 2.3.1 Pin Names and Functions (1/4)

| Pin Name         | Number of Pins | I/O    | Functions                                                                                              |  |
|------------------|----------------|--------|--------------------------------------------------------------------------------------------------------|--|
| P00 to P07       | 8              | I/O    | Port 0: I/O port that allows I/O to be selected at the bit level                                       |  |
| D0 to D7         |                | I/O    | Data (Lower): Bits 0 to 7 of data bus                                                                  |  |
| P10 to P17       | 8              | I/O    | Port 1: I/O port that allows I/O to be selected at the bit level (When used to the external 8-bit bus) |  |
| D8 to D15        |                | I/O    | Data (Upper): Bits 8 to15 of data bus                                                                  |  |
| P20 to P27       | 8              | Output | Port 2: I/O port                                                                                       |  |
| A16 to A23       |                | Output | Address: Bits 16 to 23 of address bus                                                                  |  |
| P30 to P37       | 8              | Output | Port 3: I/O port                                                                                       |  |
| A8 to A15        |                | Output | Address: Bits 8 to 15 of address bus                                                                   |  |
| P40 o P47        | 8              | Output | Port 4: I/O port                                                                                       |  |
| A0 to A7         |                | Output | Address: Bits 0 to 7 of address bus                                                                    |  |
| PZ0              | 1              | Output | Port Z0: Output port                                                                                   |  |
| RD               |                | Output | Read: Strobe signal for reading external memory                                                        |  |
| PZ1              | 1              | Output | Port Z1: Output port                                                                                   |  |
| WR               |                | Output | Write: Strobe signal for writing data to pins D0 to D7                                                 |  |
| PZ2              | 1              | I/O    | Port Z2: I/O port (with pull-up resistor)                                                              |  |
| HWR              |                | Output | High write: Strobe signal for writing data to pins D8 to D15                                           |  |
| PZ3              | 1              | I/O    | Port Z3: I/O port (with pull-up resistor)                                                              |  |
| $R/\overline{W}$ |                | Output | Read/write: 1 represents read or dummy cycle; 0 represents write cycle.                                |  |
| SRWR             |                | Output | Write for SRAM: Strobe signal for writing data.                                                        |  |
| P56              | 1              | I/O    | Port 56: I/O port (with pull-up resistor)                                                              |  |
| WAIT             |                | Input  | Wait: Pin used to request CPU bus wait                                                                 |  |
| P60              | 1              | Output | Port 60: Output port                                                                                   |  |
| CS0              |                | Output | Chip select 0: Outputs 0 when address is within specified address area.                                |  |
| P61              | 1              | Output | Port 61: Output port                                                                                   |  |
| CS1              |                | Output | Chip select 1: Outputs 0 when address is within specified address area                                 |  |
| SDCS             |                | Output | Chip select for SDRAM: Outputs 0 when address is within SDRAM address area                             |  |
| P62              | 1              | Output | Port 62: Output port                                                                                   |  |
| CS2              |                | Output | Chip select 2: Outputs 0 when address is within specified address area                                 |  |
| CS2A             |                | Output | Expand chip select 2A: Outputs 0 when address is within specified address area                         |  |
| P63              | 1              | Output | Port 63: Output port                                                                                   |  |
| CS3              |                | Output | Chip select 3: Outputs 0 when address is within specified address area                                 |  |
| P64              | 1              | Output | Port 64: Output port                                                                                   |  |
| EA24             |                | Output | Chip select 24: Outputs 0 when address is within specified address area                                |  |
| CS2B             |                | Output | Expand chip select 2B: Outputs 0 when address is within specified address area                         |  |
| P65              | 1              | Output | Port 65: Output port                                                                                   |  |
| EA25             |                | Output | Chip select 25: Outputs 0 when address is within specified address area                                |  |
| CS2C             |                | Output | Expand chip select 2C: Outputs 0 when address is within specified address area                         |  |
| P66              | 1              | Output | Port 66: Output port                                                                                   |  |
| CS2D             |                | Output | Expand chip select 2D: Outputs 0 when address is within specified address area                         |  |
| SRLB             |                | Output | Lower byte enable for SRAM: Outputs 0 when lower data is enable.                                       |  |
| P67              | 1              | Output | Port 67: Output port                                                                                   |  |
| CS2E             |                | Output | Expand chip select 2E: Outputs 0 when address is within specified address area                         |  |
| SRUB             |                | Output | Upper byte enable for SRAM: Outputs 0 when upper data is enable.                                       |  |

Table 2.3.2 Pin Names and Functions (2/4)

| Pin Name   | Number of Pins | I/O    | Functions                                                                                                   |
|------------|----------------|--------|-------------------------------------------------------------------------------------------------------------|
| P70        | 1              | I/O    | Port 70: I/O port                                                                                           |
| SCK        |                | I/O    | Serial bus interface clock I/O data at SIO mode                                                             |
| OPTRX0     |                | Input  | Serial 0 recive data                                                                                        |
| P71        | 1              | I/O    | Port 71: I/O port                                                                                           |
| S0         |                | Output | Serial bus interface send data at SIO mode                                                                  |
| SDA        |                | I/O    | Serial bus interface send/recive data at I <sup>2</sup> C bus mode (Open-drain output mode by programmable) |
| OPTRX0     |                | Output | Serial 0 send data                                                                                          |
| P72        | 1              | I/O    | Port 72: I/O port                                                                                           |
| SI         |                | Input  | Serial bus interface recive data at SIO mode                                                                |
| SCL        |                | I/O    | Serial bus interface clock I/O data at I <sup>2</sup> C bus mode (Open-drain output mode by programmable)   |
| P73        | 1              | I/O    | Port 73: I/O port                                                                                           |
| CS2F       |                | Output | Expand chip select 2F: Outputs 0 when address is within specified address area                              |
| P74        | 1              | I/O    | Port 74: I/O port                                                                                           |
| CS2G       |                | Output | Expand chip select 2G: Outputs 0 when address is within specified address area                              |
| P75        | 1              | I/O    | Port 75: I/O port                                                                                           |
| CSEXA      |                | Output | Expand chip select EXA: Outputs 0 when address is within specified address area                             |
| P76        | 1              | I/O    | Port 76: I/O port                                                                                           |
| MSK        |                | Input  | Mask: Use for disable to output VEECLK for LCD driver                                                       |
| P77        | 1              | I/O    | Port 77: I/O port                                                                                           |
| VEECLK     |                | Output | Output 32.768 kHz clock to LCD driver. (Can be disabled by MSK pin.)                                        |
| P80 to P87 | 8              | Input  | Port 80 to 87: Pin used to input ports                                                                      |
| AN0 to AN7 |                | Input  | Analog input 0 to 7: Pin used to input to AD conveter                                                       |
| ADTRG      |                | Input  | AD trigger: Signal used to request AD start (with used to P83)                                              |
| P90 to P97 | 8              | Input  | Port 90 to 97: Pin used to input ports                                                                      |
| KI0 to KI7 |                | Input  | Key input 0 to 7: Pin used of key-on wakeup 0 to 7                                                          |
|            |                |        | (Schmitt input, with pull-up resistor)                                                                      |
| PA0 to PA7 | 8              | Output | Port A0 to A7: Pin used to output ports                                                                     |
| KO0 to KO7 |                | Output | Key output 0 to 7: Pin used of key-scan strobe 0 to 7                                                       |
| PB0        | 1              | I/O    | Port B0: I/O port                                                                                           |
| TA0IN      |                | Input  | 8-bit timer 0 input: Timer 0 input                                                                          |
| TXD2       |                | Output | Serial 2 send data: Open-drain output pin by programmable                                                   |
| PB1        | 1              | I/O    | Port B1: I/O port                                                                                           |
| TA1OUT     |                | Output | 8-bit timer 1 output: Timer 1 output                                                                        |
| RXD2       |                | Input  | Serial 2 receive data                                                                                       |
| PB3        | 1              | I/O    | Port B3: I/O port                                                                                           |
| INT0       |                | Input  | Interrupt request pin0: Interrupt request pin with programmable level/rising/falling edge                   |
| PB4        | 1              | I/O    | Port B4: I/O port                                                                                           |
| INT1       |                | Input  | Interrupt request pin1: Interrupt request pin with programmable rising/falling edge                         |

Table 2.3.3 Pin Names and Functions (3/4)

| Pin Name   | Number of Pins                                | I/O    | Functions                                                                           |  |
|------------|-----------------------------------------------|--------|-------------------------------------------------------------------------------------|--|
| PB5        | 1                                             | I/O    | Port B5: I/O port                                                                   |  |
| INT2       |                                               | Input  | Interrupt request pin2: Interrupt request pin with programmable rising/falling edge |  |
| TA3OUT     |                                               | Output | 8-bit timer 3 output: Timer 3 output                                                |  |
| PB6        | 1                                             | I/O    | Port B6: I/O port                                                                   |  |
| INT3       |                                               | Input  | Interrupt request pin3: Interrupt request pin with programmable rising/falling edge |  |
| TB0OUT0    |                                               | Outout | Timer B0 output                                                                     |  |
| PC0        | 1                                             | I/O    | Port C0: I/O port                                                                   |  |
| TXD0       |                                               | Output | Serial 0 send data: Open-drain output pin by programmable                           |  |
| PC1        | 1                                             | I/O    | Port C1: I/O port                                                                   |  |
| RXD0       |                                               | Input  | Serial 0 receive data                                                               |  |
| PC2        | 1                                             | I/O    | Port C2: I/O port                                                                   |  |
| SCLK0      |                                               | I/O    | Serial 0 clock I/O                                                                  |  |
| CTS0       |                                               | Input  | Serial 0 data send enable (Clear to send)                                           |  |
| PC3        | 1                                             | I/O    | Port C3: I/O port                                                                   |  |
| TXD1       |                                               | Output | Serial 1 send data (Open-drain output pin by programmable)                          |  |
| PC4        | 1                                             | I/O    | Port C4: I/O port                                                                   |  |
| RXD1       |                                               | Input  | Serial 1 receive data                                                               |  |
| PC5        | 1                                             | I/O    | Port C5: I/O port                                                                   |  |
| SCLK1      |                                               | I/O    | Serial 1 clock I/O                                                                  |  |
| CTS1       |                                               | Input  | Serial 1 data send enable (Clear to send)                                           |  |
| PD0        | 1                                             | Output | Port D0: Output port                                                                |  |
| D1BSCP     |                                               | Output | LCD driver output pin                                                               |  |
| PD1        | 1                                             | Output | Port D1: Output port                                                                |  |
| D2BLP      |                                               | Output | LCD driver output pin                                                               |  |
| PD2        | 1                                             | Output | Port D2: Output port                                                                |  |
| D3BFR      |                                               | Output | LCD driver output pin                                                               |  |
| PD3        | 1                                             | Output | Port D3: Output port                                                                |  |
| DLEBCD     |                                               | Output | LCD driver output pin                                                               |  |
| PD4        | 1                                             | Output | Port D4: Output port                                                                |  |
| DOFFB      |                                               | Output | LCD driver output pin                                                               |  |
| PD6        | 1                                             | Output | Port D6: Output port                                                                |  |
| ALARM      |                                               | Output | RTC alarm output pin                                                                |  |
| MLDALM     | <u>                                      </u> | Output | Melody/alarm output pin (Inverted)                                                  |  |
| PD7        | 1                                             | Output | Port D7: Output port                                                                |  |
| MLDALM     |                                               | Output | Melody/alarm output pin                                                             |  |
| PE0 to PE7 | 8                                             | I/O    | Port E0 to E7: I/O port                                                             |  |
| LD0 to LD7 |                                               | Output | Data bus for LCD driver                                                             |  |
| PF0        | 1                                             | I/O    | Port F0: Output port                                                                |  |
| SDRAS      |                                               | Output | Row address storobe for SDRAM: Outputs 0 when address is within SDRAM address area  |  |
| PF1        | 1                                             | I/O    | Port F1: Output port                                                                |  |
| SDCAS      |                                               | Output | Column address storobe for SDRAM: Outputs 0 when address is within SDRAM            |  |
|            |                                               |        | address area                                                                        |  |

Table 2.3.4 Pin Names and Functions (4/4)

| Pin Name   | Number of Pins | I/O    | Functions                                                                                                    |  |
|------------|----------------|--------|--------------------------------------------------------------------------------------------------------------|--|
| PF2        | 1              | Output | Port F2: Output port                                                                                         |  |
| SDWE       |                | Output | Write enable for SDRAM                                                                                       |  |
| PF3        | 1              | Output | Port F3: Output port                                                                                         |  |
| SDLDQM     |                | Output | Lower data enable for SDRAM                                                                                  |  |
| PF4        | 1              | Output | Port F4: Output port                                                                                         |  |
| SDUDQM     |                | Output | Upper data enable for SDRAM                                                                                  |  |
| PF5        | 1              | Output | Port F5: Output port                                                                                         |  |
| SDCKE      |                | Output | Clock enable for SDRAM                                                                                       |  |
| PF6        | 1              | Output | Port F6: Output port                                                                                         |  |
| SDCLK      |                | Output | Clock for SDRAM                                                                                              |  |
| PF7        | 1              | Output | Port F7: Output port                                                                                         |  |
| PS         | 1              | Input  | Power save mode setting terminal                                                                             |  |
| NMI        |                | Input  | Non-maskable interrupt request: Interrupt request pin with programmable falling                              |  |
| (Note)     |                |        | edge level or with both edge levels programmable                                                             |  |
| AM0 to AM1 | 2              | Input  | Operation mode:                                                                                              |  |
|            |                |        | Fixed to AM1 = 1, AM0 = 1 when using internal ROM (when ROM code is 9999, setting is prohibitted).           |  |
|            |                |        | Fixed to AM1 = 0, AM0 = 1 when using external ROM by 16-bit external bus, or 8-<br>or 16-bit dynamic sizing. |  |
|            |                |        | Fixed to AM1 = 0, AM0 = 0 when using external ROM by 8-bit external bus.                                     |  |
| EMU0       | 1              | Output | Open pin                                                                                                     |  |
| EMU1       | 1              | Output | Open pin                                                                                                     |  |
| RESET      | 1              | Input  | Reset: Initializes TMP91C820A (with pull-up resistor).                                                       |  |
| VREFH      | 1              | Input  | Pin for reference voltage input to AD converter (H)                                                          |  |
| VREFL      | 1              | Input  | Pin for reference voltage input to AD converter (L)                                                          |  |
| X1/X2      | 2              | I/O    | High-frequency oscillator connection pins                                                                    |  |
| XT1/XT2    | 2              | I/O    | Low-frequency oscillator connection pins                                                                     |  |
| AVCC       | 1              |        | Power supply pin for AD converter                                                                            |  |
| AVSS       | 1              |        | GND pin for AD converter (0 V)                                                                               |  |
| DVCC       | 3              |        | Power supply pins (All VCC pins should be connecyed with the power supply pin).                              |  |
| DVSS       | 7              |        | GND pins (All pins should be connected with GND (0 V).)                                                      |  |

Note: Please input 1 into  $\overline{NMI}/\overline{PS}$  pin, because  $\overline{NMI}/\overline{PS} = 0$  means power save mode after reset.

# 3. Operation

This following describes block by block the functions and operation of the TMP91C820A.

Notes and restrictions for eatch book are outlined in 6 "Points of Note and Restrictions" at the end of this manual.

#### 3.1 CPU

The TMP91C820A incorporates a high-performance 16-bit CPU (The 900/L1 CPU). For CPU operation, see the "TLCS-900/L1 CPU".

The following describe the unique function of the CPU used in the TMP91C820A; these functions are not covered in the TLCS-900/L1 CPU section.

#### 3.1.1 Reset

When resetting the TMP91C820A microcontroller, ensure that the power supply voltage is within the operating voltage range, and that the internal high-frequency oscillator has stabilized. Then hold the  $\overline{\text{RESET}}$  input to low level for at least 10 system clocks (9µs at 36MHz).

Thus, when turn on the switch, be set to the power supply voltage is within the operating voltage range, and that the internal high-frequency oscillator has stabilized. Then hold the  $\overline{\text{RESET}}$  input to low level at least for 10 system clocks.

Clock gear is initialized 1/16 mode by reset operation. It means that the system clock mode fsys is set to fc/32 (=  $fc/16 \times 1/2$ ).

When the reset is accept, the CPU:

• Sets as follows the program counter (PC) in accordance with the reset vector stored at address FFFF00H to FFFF02H:

```
PC<7:0> \leftarrow Value at FFFF00H address
PC<15:8> \leftarrow Value at FFFF01H address
PC<23:16> \leftarrow Value at FFFF02H address
```

- Sets the stack pointer (XSP) to 100H.
- Sets bits <IFF2:0> of the status register (SR) to 111 (Sets the interrupt level mark register to level 7).
- Sets the <MAX> bit of the status register to 1 (MAX mode).
   (Note: As this product does not support MIN mode, do not write a 0 to the <MAX>.)
- Clears bits <RFP2:0> of the status register to 000 (Sets the register bank to 0).

When reset is released, the CPU starts executing instructions in accordance with the program counter settings. CPU internal registers not mentioned above do not change when the reset is released.

When the reset is accepted, the CPU sets internal I/O, ports, and other pins as follows.

Initializes the internal I/O registers.

Sets the port pins, including the pins that also act as internal I/O, to general-purpose input or output port mode.

Note: The CPU internal register (except to PC, SR, XSP) and internal RAM data do not change by resetting.

Figure 3.1.1 is a reset timing of the TMP91C820A-9999.

TOSHIBA



Figure 3.1.1 TMP91C820A-9999 Reset Timing Example (The case of using external ROM)

# 3.2 Memory Map

Figure 3.2.1 is a memory map of the TMP91C820A.



Figure 3.2.1 Memory Map

Note: Address 000FE0H to 000FFFH is assigned for the external memory area of built-in RAM type LCD driver.

And when ROM code is 9999, internal mask ROM area also defines external memory area.

# 3.3 Triple Clock Function and Standby Function

TMP91C820A contains (1) Clock gear, (2) Clock doubler (DFM), (3) Standby controller, and (4) Noise-reducing circuit. It is used for low-power, low-noise systems.

This chapter is organized as follows:

- 3.3.1 Block Diagram of System Clock
- 3.3.2 SFRs
- 3.3.3 System Clock Controller
- 3.3.4 Prescaler Clock Controller
- 3.3.5 Clock Doubler (DFM)
- 3.3.6 Noise Reduction Circuits
- 3.3.7 Standby Controller

The clock operating modes are as follows: (a) Single clock mode (X1, X2 pins only), (b) Dual clock mode (X1, X2, XT1 and XT2 pins) and (c) Triple clock mode (The X1, X2, XT1 and XT2 pins and DFM).

Figure 3.3.1 shows a transition figure.



- (c) Triple clock mode transition figure
- Note 1: It's prohibited to control DFM in SLOW mode when shifting from SLOW mode to NORMAL mode with use of DFM. (DFM start up/stop/change write to DFMCR0<ACT1:0> register.)
- Note 2: If you shift from NORMAL mode with use of DFM to NORMAL mode, the instruction should be separated into two procedures as below. Change CPU clock → Stop DFM circuit.
- Note 3: It's prohibited to shift from NORMAL mode with use of DFM to STOP mode directly. You should set NORMAL mode once, and then shift to STOP mode. (You should stop high frequency oscillator after you stop DFM.)

Figure 3.3.1 System Clock Block Diagram

The clock frequency input from the X1 and X2 pins is called fc and the clock frequency input from the XT1 and XT2 pins is called fs. The clock frequency selected by SYSCR1<SYSCK> is called the system clock fFPH. The system clock fSYS is defined as the divided clock of fFPH, and one cycle of fSYS is defined to as one state.

2006-01-31

## 3.3.1 Block Diagram of System Clock



Figure 3.3.2 Block Diagram of System Clock

## 3.3.2 SFRs

|         |             | 7                                                          | 6                                                                 | 5                                                                                                       | 4      | 3                                                                        | 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 1                                                                                        | 0                                                                                |
|---------|-------------|------------------------------------------------------------|-------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------|--------|--------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------|
| SYSCR0  | Bit symbol  | XEN                                                        | XTEN                                                              | RXEN                                                                                                    | RXTEN  | RSYSCK                                                                   | WUEF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | PRCK1                                                                                    | PRCK0                                                                            |
| (00E0H) | Read/Write  |                                                            | R/W                                                               |                                                                                                         |        |                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                          |                                                                                  |
|         | After reset | 1                                                          | 1                                                                 | 1                                                                                                       | 0      | 0                                                                        | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0                                                                                        | 0                                                                                |
|         | Function    | High-<br>frequency<br>oscillator (fc)<br>0: Stop           | Low-<br>frequency<br>oscillator (fs)<br>0: Stop<br>1: Oscillation | High-<br>frequency<br>oscillator (fc)<br>after release<br>of STOP<br>mode<br>0: Stop<br>1: Oscillation  |        | Selects clock<br>after release<br>of STOP<br>mode<br>0: fc<br>1: fs      | Warm-up timer 0: Write don't care 1: Write start timer 0: Read end warm up 1: Read do not end warm up                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Select presca<br>00: f <sub>FPH</sub> (Note<br>01: Reserved<br>10: fc/16<br>11: Reserved |                                                                                  |
|         |             | 7                                                          | 6                                                                 | 5                                                                                                       | 4      | 3                                                                        | 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 1                                                                                        | 0                                                                                |
| SYSCR1  | Bit symbol  |                                                            |                                                                   |                                                                                                         |        | SYSCK                                                                    | GEAR2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | GEAR1                                                                                    | GEAR0                                                                            |
| (00E1H) | Read/Write  |                                                            |                                                                   |                                                                                                         |        | OTOOK                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | W                                                                                        | OLANO                                                                            |
|         | After reset |                                                            | //                                                                | //                                                                                                      |        | 0                                                                        | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0                                                                                        | 0                                                                                |
|         | Function    |                                                            |                                                                   |                                                                                                         |        | Select<br>system clock<br>0: fc<br>1: fs                                 | The state of the s | ed)                                                                                      | quency (fc)                                                                      |
|         |             | 7                                                          | 6                                                                 | 5                                                                                                       | 4      | 3                                                                        | 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 1                                                                                        | 0                                                                                |
| SYSCR2  | Bit symbol  | PSENV                                                      |                                                                   | WUPTM1                                                                                                  | WUPTM0 | HALTM1                                                                   | HALTM0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | SELDRV                                                                                   | DRVE                                                                             |
| (00E2H) | Read/Write  | R/W                                                        |                                                                   | R/W                                                                                                     | R/W    | R/W                                                                      | R/W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | R/W                                                                                      | R/W                                                                              |
|         | After reset | 0                                                          |                                                                   | 1                                                                                                       | 0      | 1                                                                        | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0                                                                                        | 0                                                                                |
|         | Function    | 1:Disable<br>0:Power<br>save<br>mode<br>enable<br>(Note 3) |                                                                   | Warm-up time<br>00: Reserved<br>01: 2 <sup>8</sup> inputted<br>10:2 <sup>14</sup><br>11:2 <sup>16</sup> |        | HALT mode<br>00: Reserved<br>01: STOP mo<br>10: IDLE1 mo<br>11: IDLE2 mo | de                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | <drve><br/>mode<br/>select<br/>1: STOP<br/>0: IDLE1<br/>(Note 4)</drve>                  | Pin state control in STOP/IDLE1 mode 0: I/O off 1: Remains the state before halt |

Note 1: By reset, low-frequency oscillator is enabled.

Note 2: It's prohibit to use to fc/16 prescaler clock when SBI block use. (I<sup>2</sup>C bus and clock synchronous.)

Note 3: When use  $\overline{\text{NMI}}/\overline{\text{PS}}$  pin as  $\overline{\text{NMI}}$  function, set <PSENV> to 1.

Note 4: 0 means IDLE1, and 1 means STOP. Please be careful because this setting is sometimes different from others.

Figure 3.3.3 SFR for System Clock

| Symbol | Name           | Address |    | 7    |             | 6                                                                      | 5                     | 4                                     | 3   | 2   | 1   | 0   |
|--------|----------------|---------|----|------|-------------|------------------------------------------------------------------------|-----------------------|---------------------------------------|-----|-----|-----|-----|
|        |                |         |    | ACT1 |             | ACT0                                                                   | DLUPFG                | DLUPTM                                |     |     |     |     |
|        |                |         |    | R/W  |             | R/W                                                                    | R                     | R/W                                   |     |     |     |     |
|        |                |         |    | 0    |             | 0                                                                      | 0                     | 0                                     |     |     |     |     |
| DFMCR0 | DFM<br>control | E8H     |    | DFM  | LUP         | select<br>f <sub>FPH</sub>                                             | Lockup<br>status flag | Lockup<br>time                        |     |     |     |     |
|        | register 0     | -       | 01 | STOP | STOP        | fosch                                                                  |                       | 0: 2 <sup>12</sup> /f <sub>OSCH</sub> |     |     |     |     |
|        |                |         |    |      | RUN<br>STOP | fosch                                                                  | 1: Not end            | 1: 2 <sup>10</sup> /f <sub>OSCH</sub> |     |     |     |     |
|        |                |         |    |      | STOP        | fDFM                                                                   |                       |                                       |     |     |     |     |
|        |                |         |    |      |             | fosch                                                                  |                       |                                       |     |     |     |     |
|        |                |         |    | D7   |             | D6                                                                     | D5                    | D4                                    | D3  | D2  | D1  | D0  |
|        | DFM            |         |    | R/W  |             | R/W                                                                    | R/W                   | R/W                                   | R/W | R/W | R/W | R/W |
| DFMCR1 | control        | E9H     |    | 0    |             | 0                                                                      | 0                     | 1                                     | 0   | 0   | 1   | 1   |
|        | register 1     |         |    |      |             | DFM revision Input frequency 4 to 9 MHz (at 2.7 V to 3.6 V): Write 0BH |                       |                                       |     |     |     |     |

Figure 3.3.4 SFR for DFM

#### Limitation point on the use of DFM

- 1. It's prohibited to execute DFM enable/disable control in the SLOW mode (fs) (Write to DFMCR0<ACT1:0> = "10"). You should control DFM in the NORMAL mode.
- 2. If you stop DFM operation during using DFM (DFMCR0<ACT1:0> = "10"), you shouldn't execute that change the clock fDFM to fOSCH and stop the DFM at the same time. Therefore the above executions should be separated into two procedures as showing below.

LD (DFMCR0), C0H ; Change the clock f<sub>DFM</sub> to f<sub>OSCH</sub>.

LD (DFMCR0), 00H ; DFM stop.

3. If you stop high-frequency oscillator during using DFM (DFMCR0<ACT1:0> = "10"), you should stop DFM before you stop high-frequency oscillator.

Please refer to 3.3.5 "Clock Doubler (DFM)" for the details.

|         |             | 7            | 6                              | 5                                 | 4                              | 3              | 2                         | 1                                     | 0                         |
|---------|-------------|--------------|--------------------------------|-----------------------------------|--------------------------------|----------------|---------------------------|---------------------------------------|---------------------------|
| EMCCR0  | Bit symbol  | PROTECT      | TA3LCDE                        | AHOLD                             | TA3MLDE                        | -              | EXTIN                     | DRVOSCH                               | DRVOSCL                   |
| (00E3H) | Read/Write  | R            | R/W                            | R/W                               | R/W                            | R/W            | R/W                       | R/W                                   | R/W                       |
|         | After reset | 0            | 0                              | 0                                 | 0                              | 0              | 0                         | 1                                     | 1                         |
|         | Function    | Protect flag | LCDC                           | Address                           | Melody/alarm                   | Always write   | 1: External               | fc oscillator                         | fs oscillator             |
|         |             | 0: OFF       | Source clock                   | hold (Note)                       | source clock                   | "0".           | clock                     | driver ability                        | driver ability            |
|         |             | 1: ON        | 0: 32 kHz<br>1: TA3OUT         | 0: Disable<br>1: Enable           | 0: 32 kHz<br>1: TA3OUT         |                |                           | 1: Normal                             | 1: Normal                 |
|         | 51          |              | 1: TA3001                      | i. Enable                         | 1: TA3001                      |                |                           | 0: Weak                               | 0: Weak                   |
| EMOOD4  | Bit symbol  |              |                                |                                   |                                |                |                           |                                       |                           |
| EMCCR1  | Read/Write  |              |                                |                                   |                                |                |                           |                                       |                           |
| (00E4H) | After reset |              | Switching                      | the protect (                     | ON/OFF by w                    | rite to follow | ing 1st-KEY,              | 2nd-KEY                               |                           |
|         | Function    |              | 1st-KE                         | Y: EMCCR1                         | = 5AH, EMC                     | CR2 = A5H      | in successio              | n write                               |                           |
| EMCCR2  | Bit symbol  |              | 2nd-KE                         | Y: EMCCR1                         | = A5H, EM0                     | CCR2 = 5AH     | in succession             | n write                               |                           |
| (00E5H) | Read/Write  |              |                                |                                   |                                |                |                           |                                       |                           |
|         | After reset |              |                                |                                   |                                |                |                           |                                       |                           |
|         | Function    |              |                                |                                   |                                |                |                           |                                       |                           |
| EMCCR3  | Bit symbol  |              | ENFROM                         | ENDROM                            | ENPROM                         |                | FFLAG                     | DFLAG                                 | PFLAG                     |
| (00E6H) | Read/Write  |              | R/W                            | R/W                               | R/W                            |                | R/W                       | R/W                                   | R/W                       |
| ` ,     | After reset |              | 0                              | 0                                 | 0                              |                | 0                         | 0                                     | 0                         |
|         | Function    |              | CS1A area<br>detect<br>control | CS2B 2G<br>area detect<br>control | CS2A area<br>detect<br>control |                | CS1A write operation flag | CS2B 2G<br>write<br>operation<br>flag | CS2A write operation flag |
|         |             |              | 0: Disable                     | 0: Disable                        | 0: Disable                     |                | When readi                | ng                                    |                           |
|         |             |              | 1: Enable                      | 1: Enable                         | 1: Enable                      |                | 0: Not writte             | en                                    |                           |
|         |             |              |                                |                                   |                                |                | 1: Written                |                                       |                           |
|         |             |              |                                |                                   |                                |                | When writin               | g                                     |                           |
|         |             |              |                                |                                   |                                |                | 0: Clear flag             | J                                     |                           |

Note1: When getting access to the logic address 000000H to 000FDFH, 001000H to 002FFFH and FFE000H to FFFFFFH, A0 to A23 holds the previous address of external access.

Note2: In case restarting the oscillator in the stop oscillation state (e.g. Restart the oscillator in STOP mode), set EMCCR0<DRVOSCH>, <DRVOSCL>="1".

Figure 3.3.5 SFR for Noise Reducing

### 3.3.3 System Clock Controller

The system clock controller generates the system clock signal (fsys) for the CPU core and internal I/O. It contains two oscillation circuits and a clock gear circuit for high-frequency (fc) operation. The register SYSCR1<SYSCK> changes the system clock to either fc or fs, SYSCR0<XEN> and SYSCR0<XTEN> control enabling and disabling of each oscillator, and SYSCR1<GEAR0:2> sets the high-frequency clock gear to either 1, 2, 4, 8 or 16 (fc, fc/2, fc/4, fc/8 or fc/16). These functions can reduce the power consumption of the equipment in which the device is installed.

The combination of settings  $\langle XEN \rangle = 1$ ,  $\langle XTEN \rangle = 0$ ,  $\langle SYSCK \rangle = 0$  and  $\langle GEAR0:2 \rangle = 100$  will cause the system clock (fsys) to be set to fc/32 (fc/16 × 1/2) after a reset.

For example, f<sub>SYS</sub> is set to 1.1 MHz when the 36-MHz oscillator is connected to the X1 and X2 pins.

#### (1) Switching from NORMAL mode to SLOW mode

When the resonator is connected to the X1 and X2 pins, or to the XT1 and XT2 pins, the warm-up timer can be used to change the operation frequency after stable oscillation has been attained.

The warm-up time can be selected using SYSCR2<WUPTM0:1>.

This warm-up timer can be programmed to start and stop as shown in the following examples 1 and 2.

Table 3.3.1 shows the warm-up times.

Note 1: When using an oscillator (Other than a resonator) with stable oscillation, a warm-up timer is not needed.

Note 2: The warm-up timer is operated by an oscillation clock. Hence, there may be some variation in warm-up time.

| Warm-up Time<br>SYSCR2<br><wuptm1:0></wuptm1:0> | Change to<br>NORMAL Mode | Change to<br>SLOW Mode |  |  |  |
|-------------------------------------------------|--------------------------|------------------------|--|--|--|
| 01 (28/frequency)                               | 7.1 [μs]                 | 7.8 [ms]               |  |  |  |
| 10 (2 <sup>14</sup> /frequency)                 | 0.455 [ms]               | 500 [ms]               |  |  |  |
| 11 (2 <sup>16</sup> /frequency)                 | 1.820 [ms]               | 2000 [ms]              |  |  |  |

Table 3.3.1 Warm-up Times

at  $f_{OSCH} = 36 \text{ MHz}$ , fs = 32.768 kHz

Example 1: Setting the clock Changing from high frequency (fc) to low frequency (fs). SYSCR0 00E0H SYSCR1 EQU 00E1H SYSCR2 EQU 00E2H LD (SYSCR2), -X11----B ; Sets warm-up time to 2<sup>16</sup>/fs. SET 6, (SYSCR0) Enables low-frequency oscillation. SET 2, (SYSCR0) Clears and starts warm-up timer. WUP: 2, (SYSCR0) BIT Detects stopping of warm-up timer. JR NZ, WUP SET 3, (SYSCR1) Changes  $f_{SYS}$  from fc to fs. RES 7, (SYSCR0) Disables high-frequency oscillation.

X: Don't care, -: No change



| Example 2: | Setting t | Setting the clock            |      |                                           |  |  |  |  |  |
|------------|-----------|------------------------------|------|-------------------------------------------|--|--|--|--|--|
|            | Changin   | g from low frequency (fs) to | high | frequency (fc).                           |  |  |  |  |  |
| SYSCR0     | EQU       | 00E0H                        |      |                                           |  |  |  |  |  |
| SYSCR1     | EQU       | 00E1H                        |      |                                           |  |  |  |  |  |
| SYSCR2     | EQU       | 00E2H                        |      |                                           |  |  |  |  |  |
|            | LD        | (SYSCR2), -X10B              | ;    | Sets warm-up time to 2 <sup>14</sup> /fc. |  |  |  |  |  |
|            | SET       | 7, (SYSCR0)                  | ;    | Enables high-frequency oscillation.       |  |  |  |  |  |
|            | SET       | 2, (SYSCR0)                  | ;    | Clears and starts warm-up timer.          |  |  |  |  |  |
| WUP:       | BIT       | 2, (SYSCR0)                  | ; ¬  | Detects stopping of warm-up timer.        |  |  |  |  |  |
|            | JR        | NZ, WUP                      | ;    | Detects stopping of warm-up timer.        |  |  |  |  |  |
|            | RES       | 3, (SYSCR1)                  | ;    | Changes f <sub>SYS</sub> from fs to fc.   |  |  |  |  |  |
|            | RES       | 6, (SYSCR0)                  | ;    | Disables low-frequency oscillation.       |  |  |  |  |  |

X: Don't care, -: No change



TOSHIBA

#### (2) Clock gear controller

When the high-frequency clock fc is selected by setting SYSCR1<SYSCK> = 0, fFPH is set according to the contents of the clock gear select register SYSCR1<GEAR0:2> to either fc, fc/2, fc/4, fc/8 or fc/16. Using the clock gear to select a lower value of fFPH reduces power consumption.

(High-speed clock gear changing)

To change the clock gear, write the register value to the SYSCR1<GEAR2:0> register. It is necessary the warm-up time until changing after writing the register value.

There is the possibility that the instruction next to the clock gear changing instruction is executed by the clock gear before changing. To execute the instruction next to the clock gear switching instruction by the clock gear after changing, input the dummy instruction as follows (Instruction to execute the write cycle).

```
(Example)

SYSCR1 EQU 00E1H

LD (SYSCR1), XXXX0001B ; Changes f<sub>SYS</sub> to fc/4.

LD (DUMMY), 00H ; Dummy instruction.

Instruction to be executed after clock gear has changed.
```

#### 3.3.4 Prescaler Clock Controller

For the internal I/O (TMRA01 to TMRA23, SIO0 to SIO1,SBI) there is a prescaler which can divide the clock.

The  $\phi T$  clock input to the prescaler is either the clock fFPH divided by 2 or the clock fc/16 divided by 2. The setting of the SYSCR0<PRCK0:1> register determines which clock signal is input. When it's used internal SBI circuit, <PRCK1:0> register must be set to 00.

### 3.3.5 Clock Doubler (DFM)

DFM outputs the f<sub>DFM</sub> clock signal, which is four times as fast as f<sub>OSCH</sub>. It can use the low-frequency oscillator, even though the internal clock is high frequency.

A reset initializes DFM to stop status, setting to DFMCR0 register is needed before use. Like an oscillator, this circuit requires time to stabilize. This is called the lockup time. The following example shows how DFM is used.

| DFMCR0 | EQU | 00E8H               |     |                                                                                        |
|--------|-----|---------------------|-----|----------------------------------------------------------------------------------------|
| DFMCR1 | EQU | 00E9H               |     |                                                                                        |
|        | LD  | (DFMCR1), 0BH       | ;   | Parameter setting.                                                                     |
|        | LD  | (DFMCR0), 01X0XXXXB | ;   | Set lockup time to 2 <sup>12</sup> /4 MHz.<br>Enables DFM operation and starts lockup. |
| LUP:   | BIT | 5, (DFMCR0)         | ; ] | Detects end of lockup.                                                                 |
|        | JR  | NZ, LUP             | ; } | _ Detects end of lockup.                                                               |
|        | LD  | (DFMCR0), 10X0XXXXB | ر;  | Changes fc from 4 MHz to 16 MHz.                                                       |

X: Don't care



Note: Input frequency limitation and correction for DFM.

Recommend to use input frequency (High-speed oscillation) for DFM in the following condition.

fosch = 4 MHz to 9 MHz (Vcc = 2.7 V to 3.6 V): Write 0BH to DFMCR1.

#### <u>Limitation point on the use of DFM</u>

- 1. It's prohibited to execute DFM enable/disable control in the SLOW mode (fs) (Write to DFMCR0<ACT1:0> = "10"). You should control DFM in the NORMAL mode.
- 2. If you stop DFM operation during using DFM (DFMCR0<ACT1:0> = "10"), you shouldn't execute the commands that change the clock fDFM to fOSCH and stop the DFM at the same time. Therefore the above execution should be separated into two procedures as showing below.

```
LD (DFMCR0), C0H ; Change the clock f_{DFM} to f_{OSCH}. LD (DFMCR0), 00H ; DFM stop.
```

3. If you stop high-frequency oscillator during using DFM (DFMCR0<ACT1:0> = "10"), you should stop DFM before you stop high-frequency oscillator.

Examples of settings are below.

(1) Start up/change control

(OK) Low-frequency oscillator operation mode (fs) (high-frequency oscillator stop) → High-frequency oscillator start up → High-frequency oscillator operation mode (fosch)

 $\rightarrow$  DFM start up  $\rightarrow$  DFM use mode (f<sub>DFM</sub>)

```
(SYSCR0), 11---1--B
             LD
                                            ; High-frequency oscillator start-up/warm-up start.
WUP:
             BIT
                     2, (SYSCR0)
                                                 Check for the flag of lockup end.
             JR
                     NZ, WUP
                     (SYSCR1), ----0---B; Change the system clock fs to fosch.
            I D
                     (DFMCR0), 01-0---B; DFM start-up/lockup start.
            LD
LUP:
             BIT
                     5, (DFMCR0)
                                                Check for the flag of lockup end.
                     NZ, LUP
             JR.
             ΙD
                     (DFMCR0), 10-0---B
                                                 Change the system clock.
```

(OK) Low-frequency oscillator operation mode (fs) (high-frequency oscillator operate)  $\rightarrow$  High-frequency oscillator operation mode (fosch)  $\rightarrow$  DFM start up  $\rightarrow$  DFM use mode (fDFM)

(Error) Low-frequency oscillator operation mode (fs) (High-frequency oscillator stop)

 $\rightarrow$  High-frequency oscillator start up  $\rightarrow$  DFM start up  $\rightarrow$  DFM use mode (fDFM)

```
; High-frequency oscillator start-up/warm-up start.
             ΙD
                       (SYSCR0), 11---1--B
WUP:
             BIT
                       2, (SYSCR0)
                                                   Check for the flag of lockup end.
             JR
                       NZ, WUP
                                               ; DFM start-up/lockup start.
             LD
                       (DFMCR0), 01-0---B
                       5, (DFMCR0)
LUP:
             BIT
                                                  Check for the flag of lockup end.
             JR
                       NZ, LUP
             LD
                       (DFMCR0), 10-0---B
                                               ; Change the internal clock fosch to form.
                       (SYSCR1), ----0---B ; Change the system clock f<sub>S</sub> to f<sub>DFM</sub>.
             LD
```

#### (2) Change/stop control

(OK) DFM use mode (fDFM)  $\rightarrow$  High-frequency oscillator operation mode (fOSCH)  $\rightarrow$  DFM stop  $\rightarrow$  Low-frequency oscillator operation mode (fs)  $\rightarrow$  High-frequency oscillator stop

(Error) DFM use mode (fDFM)  $\rightarrow$  Low-frequency oscillator operation mode (fs)  $\rightarrow$  DFM stop  $\rightarrow$  High-frequency oscillator stop

```
LD (SYSCR1), ----1---B ; Change the system clock f<sub>DFM</sub> to fs.

LD (DFMCR0), 11-----B ; Change the internal clock (fc) f<sub>DFM</sub> to f<sub>OSCH</sub>.

LD (DFMCR0), 00------B ; DFM stop.

LD (SYSCR0), 0------B ; High-frequency oscillator stop.
```

(OK) DFM use mode (f<sub>DFM</sub>)  $\rightarrow$  Set the STOP mode  $\rightarrow$  High-frequency oscillator operation mode (f<sub>OSCH</sub>)  $\rightarrow$  DFM stop  $\rightarrow$  Halt (High-frequency oscillator stop)

```
LD (SYSCR2), ----01--B ; Set the STOP mode.

(This command can execute before use of DFM.)

LD (DFMCR0), 11-----B ; Change the system clock f<sub>DFM</sub> to f<sub>OSCH</sub>.

LD (DFMCR0), 00-----B ; DFM stop.

HALT : Shift to STOP mode.
```

(Error) DFM use mode (fDFM)  $\rightarrow$  Set the STOP mode  $\rightarrow$  Halt (High-frequency oscillator stop)

```
LD (SYSCR2), ----01--B ; Set the STOP mode.

(This command can execute before use of DFM.)

HALT ; Shift to STOP mode.
```

#### 3.3.6 Noise Reduction Circuits

Noise reduction circuits are built in, allowing implementation of the following features.

- (1) Reduced drivability for high-frequency oscillator
- (2) Reduced drivability for low-frequency oscillator
- (3) Single drive for high-frequency oscillator
- (4) Runaway provision with SFR protection register
- (5) Runaway provision with ROM protection register

The above functions are performed by making the appropriate settings in the EMCCR0 to EMCCR3 registers.

#### (1) Reduced drivability for high-frequency oscillator

#### (Purpose)

Reduces noise and power for oscillator when a resonator is used.

#### (Block diagram)



#### (Setting method)

The drivability of the oscillator is reduced by writing 0 to EMCCR0<DRVOSCH> register. By reset, <DRVOSCH> is initialized to 1 and the oscillator starts oscillation by normal drivability when the power supply is on.

#### (2) Reduced drivability for low-frequency oscillator

#### (Purpose)

Reduces noise and power for oscillator when a resonator is used.

#### (Block diagram)



#### (Setting method)

The drivability of the oscillator is reduced by writing 0 to the EMCCR0<DRVOSCL> register. By reset, <DRVOSCL> is initialized to 1.

#### (3) Single drive for high-frequency oscillator

#### (Purpose)

Not need twin-drive and protect mistake operation by inputted noise to X2 pin when the external oscillator is used.

#### (Block diagram)



#### (Setting method)

The oscillator is disabled and starts operation as buffer by writing 1 to EMCCR0<EXTIN> register. X2 pin is always outputted 1.

By reset, <EXTIN> is initialized to 0.

Note: Do not write EMCCR0<EXTIN> = "1" when using external resonator.

(4) Runaway provision with SFR protection register

(Purpose)

Provision in runaway of program by noise mixing.

Write operation to specified SFR is prohibited so that provision program in runaway prevents that it is it in the state which is fetch impossibility by stopping of clock, memory control register (CS/WAIT controller, MMU) is changed.

And error handling in runaway becomes easy by INTP0 interruption.

#### Specified SFR list

1. CS/WAIT controller

BOCS, B1CS, B2CS, B3CS, BEXCS, MSAR0, MSAR1, MSAR2, MSAR3, MAMR0, MAMR1, MAMR2, MAMR3

2. MMU

LOCAL0/1/2/3

3. Clock gear

SYSCR0, SYSCR1, SYSCR2, EMCCR0, EMCCR3

4. DFM

DFMCR0/1

(Operation explanation)

Execute and release of protection (Write operation to specified SFR) become possible by setting up a double key to EMCCR1 and EMCCR2 register.

(Double key)

1st-KEY: Succession writes in 5AH at EMCCR1 and A5H at EMCCR2 2nd-KEY: Succession writes in A5H at EMCCR1 and 5AH at EMCCR2

A state of protection can be confirmed by reading EMCCR0<PROTECT>.

By reset, protection becomes OFF.

And INTPO interruption occurs when write operation to specified SFR was executed with protection on state.

(5) Runaway provision with ROM protection register

(Purpose)

Provision in runaway of program by noise mixing.

(Operation explanation)

When writes operation was executed for external three kinds of ROM by runaway of program, INTP1 is occurred and detects runaway function.

Three kinds of ROM is fixed as for flash ROM (Option program ROM), data ROM, program ROM are as follows on the logical address memory map.

- 1. Flash ROM: Address 400000H to 7FFFFFH
- 2. Data ROM: Address 800000H to BFFFFFH
- 3. Program ROM: Address C00000H to FFFFFFH

For these address, admission/prohibition of detection of write operation sets it up with EMCCR3<ENFROM, ENDROM, ENPROM>. And INTP1 interruption occurred with which ROM area in the case that occurred can confirm each with EMCCR3<FFLAG, DFLAG, and PFLAG>. This flag is cleared when write in 0.

TMP91C820A

## 3.3.7 Standby Controller

#### (1) HALT modes

When the HALT instruction is executed, the operating mode switches to IDLE2, IDLE1 or STOP mode, depending on the contents of the SYSCR2<HALTM1:0> register.

The subsequent actions performed in each mode are as follows:

a. IDLE2: Only the CPU halts.

The internal I/O is available to select operation during IDLE2 mode by setting the following register.

Table 3.3.2 shows the registers of setting operation during IDLE2 mode.

Table 3.3.2 SFR Setting Operation during IDLE2 Mode

| SFR                       |
|---------------------------|
| TA01RUN <i2ta01></i2ta01> |
| TA23RUN <i2ta23></i2ta23> |
| TB0RUN <i2tb0></i2tb0>    |
| SC0MOD1 <i2s0></i2s0>     |
| SC1MOD1 <i2s1></i2s1>     |
| ADMOD1 <i2ad></i2ad>      |
| WDMOD <i2wdt></i2wdt>     |
| SBI0BR0 <i2sbi0></i2sbi0> |
|                           |

- b. IDLE1: Only the oscillator and the RTC (Real time clock) and MLD continue to operate.
- c. STOP: All internal circuits stop operating.

The operation of each of the different HALT modes is described in Table 3.3.3.

Table 3.3.3 I/O Operation during HALT Modes

| HALT Mode                    |                      | IDLE2                                                  | IDLE1                       | STOP |  |  |  |
|------------------------------|----------------------|--------------------------------------------------------|-----------------------------|------|--|--|--|
| SYSCR2 <haltm1:0></haltm1:0> |                      | 11                                                     | 10                          | 01   |  |  |  |
|                              | CPU                  | Stop                                                   |                             |      |  |  |  |
| Block                        | I/O ports            | Keep the state when the HALT instruction was executed. | Table 3.3.6 and Table 3.3.7 |      |  |  |  |
|                              | TMRA,TMRB0           |                                                        | Stop                        |      |  |  |  |
|                              | SIO, SBI             | Available to select                                    |                             |      |  |  |  |
|                              | AD converter         | operation block                                        |                             |      |  |  |  |
|                              | WDT                  |                                                        |                             |      |  |  |  |
|                              | LCDC, SDRAMC         |                                                        |                             |      |  |  |  |
|                              | Interrupt controller | Operate                                                |                             |      |  |  |  |
|                              | RTC, MLD             | Spordio                                                | Operational available       |      |  |  |  |

#### (2) How to release the HALT mode

These halt states can be released by resetting or requesting an interrupt. The halt release sources are determined by the combination between the states of interrupt mask register <IFF2:0> and the HALT modes. The details for releasing the halt status are shown in Table 3.3.4.

#### Released by requesting an interrupt

The operating released from the HALT mode depends on the interrupt enabled status. When the interrupt request level set before executing the halt instruction exceeds the value of interrupt mask register, the interrupt due to the source is processed after releasing the HALT mode, and CPU status executing an instruction that follows the halt instruction. When the interrupt request level set before executing the halt instruction is less than the value of the interrupt mask register, releasing the HALT mode is not executed (in non-maskable interrupts, interrupt processing is processed after releasing the HALT mode regardless of the value of the mask register). However only for INTO to INT3 and INTKEY and INTRTC, INTALMO to INTALM4, even if the interrupt request level set before executing the halt instruction is less than the value of the interrupt mask register, releasing the the HALT mode is executed. In this case, interrupt processing, and CPU starts executing the instruction next to the HALT instruction, but the interrupt request flag is held at 1.

Note: Usually, interrupts can release all halt status. However, the interrupts (NMI, INT0 to INT3, INTKEY, INTRTC, INTALM0 to INTALM4) which can release the HALT mode may not be able to do so if they are input during the period CPU is shifting to the HALT mode (for about 5 clocks of f<sub>FPH</sub>) with IDLE1 or STOP mode (IDLE2 is not applicable to this case). (In this case, an interrupt request is kept on hold internally.)

If another interrupt is generated after it has shifted to the HALT mode completely, halt status can be released without difficulty. The priority of this interrupt is compared with that of the interrupt kept on hold internally, and the interrupt with higher priority is handled first followed by the other interrupt.

#### • Releasing by resetting

Releasing all halt status is executed by resetting.

When the stop mode is released by reset, it is necessry enough resetting time (See Table 3.3.5) to set the operation of the oscillator to be stable.

When releasing the HALT mode by resetting, the internal RAM data keeps the state before the HALT instruction is executed. However the other settings contents are initialized. (Releasing due to interrupts keeps the state before the HALT instruction is executed.)

|                                | Status of Received Interrupt |                                      | Interrupt Enabled<br>(Interrupt level) ≥ (Interrupt mask) |       |                 | Interrupt Disabled<br>(Interrupt level) < (Interrupt mask) |       |      |  |
|--------------------------------|------------------------------|--------------------------------------|-----------------------------------------------------------|-------|-----------------|------------------------------------------------------------|-------|------|--|
| HALT mode                      |                              | HALT mode                            | IDLE2                                                     | IDLE1 | STOP            | IDLE2                                                      | IDLE1 | STOP |  |
| Source of halt state clearance | Interrupt                    | NMI                                  | •                                                         | •     | <b>♦</b> *1     | -                                                          | -     | -    |  |
|                                |                              | INTWDT                               | •                                                         | ×     | ×               | =                                                          | -     | =    |  |
|                                |                              | INT0 to INT3 (Note 1)                | •                                                         | •     | <b>♦</b> *1     | 0                                                          | 0     | 0*1  |  |
|                                |                              | INTALM0 to INTALM4                   | •                                                         | •     | ×               | 0                                                          | 0     | ×    |  |
|                                |                              | INTTA0 to INTTA3, INTTB00 to INTTB01 | •                                                         | ×     | ×               | ×                                                          | ×     | ×    |  |
|                                |                              | INTRX0 to INTRX2, TX0 to TX2         | •                                                         | ×     | ×               | ×                                                          | ×     | ×    |  |
|                                |                              | INTSS0 to INTSS2                     | •                                                         | ×     | ×               | ×                                                          | ×     | ×    |  |
|                                |                              | INTAD                                | •                                                         | ×     | ×               | ×                                                          | ×     | ×    |  |
|                                |                              | INTKEY                               | •                                                         | •     | ◆* <sup>1</sup> | 0                                                          | 0     | 0*1  |  |
|                                |                              | INTRTC                               | •                                                         | •     | ×               | 0                                                          | 0     | ×    |  |
|                                |                              | INTSBI                               | •                                                         | ×     | ×               | ×                                                          | ×     | ×    |  |
|                                |                              | INTLCD                               | •                                                         | ×     | ×               | ×                                                          | ×     | ×    |  |
|                                |                              | RESET                                | Initialize LSI.                                           |       |                 |                                                            |       |      |  |

Table 3.3.4 Source of Halt State Clearance and Halt Clearance Operation

- ◆: After clearing the HALT mode, CPU starts interrupt processing.
- o: After clearing the HALT mode, CPU resumes executing starting from instruction following the HALT instruction.
- x: It can not be used to release the HALT mode .
- -: The priority level (Interrupt request level) of non-maskable interrupts is fixed to 7, the highest priority level. There is not this combination type.
- \*1: Releasing the HALT mode is executed after passing the warm-up time.

Note: When the HALT mode is cleared by an INT0 interrupt of the level mode in the interrupt enabled status, hold level H until starting interrupt processing. If level L is set before holding level L, interrupt processing is correctly started.

#### (Example releasing IDLE1 mode)

An INT0 interrupt clears the halt state when the device is in IDLE1 mode.



#### (3) Operation

#### a. IDLE2 mode

In IDLE2 mode only specific internal I/O operations, as designated by the IDLE2 setting register, can take place. Instruction execution by the CPU stops.

Figure 3.3.6 illustrates an example of the timing for clearance of the IDLE2 mode halt state by an interrupt.



Figure 3.3.6 Timing Chart for IDLE2 Mode Halt State Cleared by Interrupt

#### b. IDLE1 mode

In IDLE1 mode, only the internal oscillator and the RTC, MLD continue to operate. The system clock in the MCU stops. The pin status in the IDLE1 mode is depended on setting the register SYSCR2<SELDRV, DRVE>., Table 3.3.6 and Table 3.3.7 summarizes the state of these pins in the IDLE1 mode.

In the halt state, the interrupt request is sampled asynchronously with the system clock; however, clearance of the halt state (e.g., restart of operation) is synchronous with it.

Figure 3.3.7 illustrates the timing for clearance of the IDLE1 mode halt state by an interrupt.



Figure 3.3.7 Timing Chart for IDLE1 Mode Halt State Cleared by Interrupt

### c. STOP mode

When STOP mode is selected, all internal circuits stop, including the internal oscillator pin status in STOP mode depends on the settings in the SYSCR2<SELDRV, DRVE> register. Table 3.3.6, Table 3.3.7 summarizes the state of these pins in STOP mode.

After STOP mode has been cleared system clock output starts when the warm-up time has elapsed, in order to allow oscillation to stabilize. After STOP mode has been cleared, either NORMAL mode or SLOW mode can be selected using the SYSCRO<RSYSCK> register. Therefore, <RSYSCK>, <RXEN> and <RXTEN> must be set see the sample warm-up times in Table 3.3.5.

Figure 3.3.8 illustrates the timing for clearance of the STOP mode halt state by an interrupt.



Figure 3.3.8 Timing Chart for STOP Mode Halt State Cleared by Interrupt

Table 3.3.5 Sample Warm-up Times after Clearance of STOP Mode

at  $f_{OSCH} = 36$  MHz,  $f_{S} = 32.768$  kHz

| SYSCR0            | SYSCR2 <wuptm1:0></wuptm1:0> |                       |                       |  |  |  |  |  |  |  |
|-------------------|------------------------------|-----------------------|-----------------------|--|--|--|--|--|--|--|
| <rsysck></rsysck> | 01 (2 <sup>8</sup> )         | 10 (2 <sup>14</sup> ) | 11 (2 <sup>16</sup> ) |  |  |  |  |  |  |  |
| 0 (fc)            | 7.1 µs                       | 0.455 ms              | 1.820 ms              |  |  |  |  |  |  |  |
| 1 (fs)            | 7.8 ms                       | 500 ms                | 2000 ms               |  |  |  |  |  |  |  |

(Setting example)

The STOP mode is entered when the low frequency operates, and high frequency operates after releasing due to NMI.



Note: When different modes are used before and after STOP mode as the above mentioned, there is possible to release the HALT mode without changing the operation mode by acceptance of the halt release interrupt request during execution of halt instruction (during 6 state). In the system which accepts the interrupts during execution HALT instruction, set the same operation mode before and after the STOP mode.

Table 3.3.6 Input buffer state table (1/2)

|              |                  |                                                                          |                                    | 0.0.0                         |                                        | out Buffer St                 |                                    |                               |                                    |                               |
|--------------|------------------|--------------------------------------------------------------------------|------------------------------------|-------------------------------|----------------------------------------|-------------------------------|------------------------------------|-------------------------------|------------------------------------|-------------------------------|
|              |                  |                                                                          | When th                            | e CPU is                      | In HAL                                 |                               |                                    | n HALT mode                   | e(IDLE1/STC                        | OP)                           |
| Dort         | Input            |                                                                          |                                    | ating                         | (IDL                                   |                               | Condition                          |                               |                                    | n B (Note)                    |
| Port<br>Name | Function<br>Name | During<br>Reset                                                          | When<br>Used as<br>function<br>Pin | When<br>Used as<br>Input Port | When<br>Used as<br>function<br>Pin     | When<br>Used as<br>Input Port | When<br>Used as<br>function<br>Pin | When<br>Used as<br>Input Port | When<br>Used as<br>function<br>Pin | When Used<br>as Input<br>Port |
| P00-P07      | D0-D7            | OFF                                                                      |                                    | ON upon port read             |                                        |                               |                                    |                               |                                    |                               |
| P10-P17      | D8-D15           | 8bit start:<br>OFF<br>16bit start:<br>ON<br>Built-in<br>ROM start:<br>ON | ON upon<br>external<br>read        |                               | ON upon<br>external<br>read of<br>LCDC | OFF                           | OFF                                |                               | OFF                                | OFF                           |
| P20-P27      | _                | 8bit start:                                                              |                                    |                               |                                        | 011                           |                                    |                               |                                    | 011                           |
| P30-P37      | -                | OFF                                                                      |                                    |                               |                                        |                               |                                    |                               |                                    |                               |
| P40-P47      | -                | 16bit start:<br>OFF<br>Built-in<br>ROM start:<br>ON                      | -                                  | ON                            | _                                      |                               | -                                  |                               | -                                  |                               |
| PZ2 (*1)     | -                |                                                                          |                                    |                               |                                        |                               |                                    |                               |                                    |                               |
| PZ3 (*1)     | _                |                                                                          |                                    |                               |                                        |                               |                                    |                               |                                    |                               |
| P56 (*1)     | WAIT             |                                                                          |                                    |                               |                                        |                               |                                    | OFF                           |                                    |                               |
| P70          | SCK,<br>OPTRX0   |                                                                          | ON                                 |                               | ON                                     |                               | OFF                                |                               | ON                                 |                               |
| P71          | SDA              | ON                                                                       |                                    |                               |                                        |                               |                                    | -                             |                                    |                               |
| P72          | SI, SCL          |                                                                          |                                    |                               |                                        | ON                            | ON                                 | -                             |                                    | ON                            |
| P73<br>P74   |                  |                                                                          |                                    |                               |                                        |                               |                                    |                               |                                    |                               |
| P74<br>P75   | _                |                                                                          | _                                  |                               | _                                      |                               | _                                  |                               | _                                  |                               |
| P76          | MSK              |                                                                          | ON                                 |                               | ON                                     |                               | OFF                                | -                             | ON                                 |                               |
| P77          | -                |                                                                          | OIV                                | ON                            | OIV                                    |                               | 011                                | -                             | OIV                                |                               |
| P80 (*2)     | _                |                                                                          |                                    | OIT                           |                                        |                               |                                    |                               |                                    |                               |
| P81 (*2)     | _                |                                                                          | _                                  |                               | _                                      |                               | _                                  |                               | _                                  |                               |
| P82 (*2)     | _                |                                                                          |                                    |                               |                                        |                               |                                    |                               |                                    |                               |
| P83 (*2)     | ADTRG            | 055                                                                      | ON                                 | ON upon                       | ON                                     | ٥٣٦                           | ON                                 |                               | ON                                 | OFF                           |
| P84 (*2)     | -                | OFF                                                                      |                                    | port read                     |                                        | OFF                           |                                    |                               |                                    | OFF                           |
| P85 (*2)     | -                |                                                                          | _                                  |                               | _                                      |                               | _                                  |                               | _                                  |                               |
| P86 (*2)     | -                |                                                                          | _                                  |                               | _                                      |                               | _                                  |                               | _                                  |                               |
| P87 (*2)     | -                |                                                                          |                                    |                               |                                        |                               |                                    |                               |                                    |                               |
| P90 (*1)     | KI0              |                                                                          |                                    |                               |                                        |                               |                                    |                               |                                    |                               |
| P91 (*1)     | KI1              |                                                                          |                                    |                               |                                        |                               |                                    |                               |                                    |                               |
| P92 (*1)     | KI2              |                                                                          |                                    |                               |                                        |                               |                                    |                               |                                    |                               |
| P93 (*1)     | KI3              |                                                                          |                                    |                               |                                        |                               | ON                                 | ON                            |                                    |                               |
| P94 (*1)     | KI4              |                                                                          |                                    |                               |                                        | 011                           |                                    |                               |                                    | 011                           |
| P95 (*1)     | KI5              |                                                                          |                                    |                               |                                        | ON                            |                                    |                               |                                    | ON                            |
| P96 (*1)     | KI6              | ON                                                                       | ON                                 | ON                            | ON                                     |                               |                                    |                               | ON                                 |                               |
| P97 (*1)     | KI7              |                                                                          |                                    |                               |                                        |                               |                                    |                               |                                    |                               |
| PB0          | TA0IN            |                                                                          |                                    |                               |                                        |                               | OFF                                | OFF                           |                                    |                               |
| PB1<br>PB3   | RXD2<br>INT0     |                                                                          |                                    |                               |                                        |                               |                                    | ONI                           |                                    |                               |
| PB3<br>PB4   | INT1             |                                                                          |                                    |                               |                                        |                               |                                    | ON                            |                                    |                               |
| PB5          | INT2             |                                                                          |                                    |                               |                                        | OFF                           | ON                                 | OFF                           |                                    | OFF                           |
| PB6          | INT3             |                                                                          |                                    |                               |                                        | 511                           |                                    |                               |                                    | J. 1                          |
| 1 00         | IIVIO            |                                                                          | l                                  |                               | l                                      |                               |                                    |                               |                                    |                               |

Input buffer state table (2/2)

|               |                  |                 |                                    |                               |                                    | put Buffer St                 | ate                                |                               |                                    |                               |
|---------------|------------------|-----------------|------------------------------------|-------------------------------|------------------------------------|-------------------------------|------------------------------------|-------------------------------|------------------------------------|-------------------------------|
|               |                  |                 | When th                            | e CPU is                      | In HAL                             | T mode                        | Ir                                 | n HALT mode                   | (IDLE1/STC                         | P)                            |
| Port          | Input            |                 | opei                               | ating                         | (IDL                               | _E2)                          | Condition                          | A (Note)                      | Conditio                           | n B (Note)                    |
| Name          | Function<br>Name | During<br>Reset | When<br>Used as<br>function<br>Pin | When<br>Used as<br>Input Port | When<br>Used as<br>function<br>Pin | When<br>Used as<br>Input Port | When<br>Used as<br>function<br>Pin | When<br>Used as<br>Input Port | When<br>Used as<br>function<br>Pin | When Used<br>as Input<br>Port |
| PB0           | TA0IN            |                 |                                    |                               |                                    |                               | OFF                                | OFF                           |                                    |                               |
| PB1           | RXD2             |                 |                                    |                               |                                    | ON                            | 011                                | 011                           |                                    | ON                            |
| PB3           | INT0             |                 | ON                                 |                               | ON                                 |                               |                                    | ON                            | ON                                 |                               |
| PB4           | INT1             |                 |                                    |                               | OIT                                |                               | ON                                 |                               | OIT                                |                               |
| PB5           | INT2             |                 |                                    |                               |                                    | OFF                           | OI                                 |                               |                                    | OFF                           |
| PB6           | INT3             |                 |                                    |                               |                                    |                               |                                    |                               |                                    |                               |
| PC0           | _                |                 | _                                  |                               | _                                  | ]                             | _                                  |                               | _                                  |                               |
| PC1           | RXD0             |                 |                                    | ON                            |                                    |                               |                                    |                               |                                    |                               |
| PC2           | SCLK0,<br>CTS0   |                 | ON                                 |                               | ON                                 | 011                           | OFF                                | OFF                           | ON                                 | 011                           |
| PC3           | _                | ON              | _                                  |                               | -                                  | ON                            | -                                  |                               | _                                  | ON                            |
| PC4           | RXD1             |                 |                                    |                               |                                    | ] [                           |                                    |                               |                                    |                               |
| PC5           | SCLK1,<br>CTS1   |                 | ON                                 |                               | ON                                 |                               | OFF                                |                               | ON                                 |                               |
| PE0-PE7       | _                |                 | _                                  |                               | -                                  | OFF                           | _                                  |                               | -                                  | OFF                           |
| NMI/PS        | _                |                 |                                    |                               |                                    |                               |                                    |                               |                                    |                               |
| RESET<br>(*1) | -                |                 | 011                                |                               | 011                                |                               | ON                                 | _                             | ON                                 | _                             |
| AMO,<br>AM1   | -                |                 | ON                                 | _                             | ON                                 | _                             |                                    |                               |                                    |                               |
| X1, XT1       | _                |                 |                                    |                               |                                    |                               |                                    | IDLE1: ON,                    | STOP: OFF                          | =                             |

ON: The buffer is always turned on. A current flows the input buffer if the input pin is not driven.

OFF: The buffer is always turned off.

Note: Condition A/B are as follows.

| SYSCR2 re     | egister setting   | HALT        | mode        |  |
|---------------|-------------------|-------------|-------------|--|
| <drve></drve> | <seldrv></seldrv> | IDLE1       | STOP        |  |
| 0             | 0                 | Condition A | Condition A |  |
| 0             | 1                 |             | Condition A |  |
| 1             | 0                 | Condition B | Condition B |  |
| 1             | 1                 |             | Condition B |  |

<sup>\*1:</sup> Port having a pull-up/pull-down resistor.

<sup>\*2:</sup> AIN input does not cause a current to flow through the buffer.

<sup>-:</sup> No applicable

Table 3.3.7 Output buffer state table (1/2)

|            |                |                    |                 | 0 0.0.7 0 0    | •               | put Buffer Sta | , ,             |                |                 |                |  |  |  |  |   |  |  |  |  |  |  |  |  |
|------------|----------------|--------------------|-----------------|----------------|-----------------|----------------|-----------------|----------------|-----------------|----------------|--|--|--|--|---|--|--|--|--|--|--|--|--|
|            |                |                    | When th         | e CPU is       |                 |                |                 | HALT mode      | (IDLE1/STC      | P)             |  |  |  |  |   |  |  |  |  |  |  |  |  |
| Port       | Output         |                    | oper            | ating          | In HALT mo      | ode (IDLE2)    | Condition       | n A (Note)     | Condition       | B (Note)       |  |  |  |  |   |  |  |  |  |  |  |  |  |
| Name       | Function       | During             | When            | When           | When            | When           | When            | When           | When            | When           |  |  |  |  |   |  |  |  |  |  |  |  |  |
|            | Name           | Reset              | Used as         | Used as        |  |  |  |  |   |  |  |  |  |  |  |  |  |
|            |                |                    | function<br>Pin | Output<br>Port | function<br>Pin | Output<br>Port | function<br>Pin | Output<br>Port | function<br>Pin | Output<br>Port |  |  |  |  |   |  |  |  |  |  |  |  |  |
| P00-P07    | D0-D7          |                    | ON upon         | FUIL           | ГШ              | FUIL           | ГШ              | FUIL           | ГШ              | FUIL           |  |  |  |  |   |  |  |  |  |  |  |  |  |
|            |                | OFF                | external        |                | OFF             |                |                 |                | OFF             |                |  |  |  |  |   |  |  |  |  |  |  |  |  |
| P10-P17    | D8-D15         |                    | read            |                |                 |                |                 |                |                 |                |  |  |  |  |   |  |  |  |  |  |  |  |  |
| P20-P27    | A16-A23        | 8bit start:        |                 |                |                 |                |                 |                |                 |                |  |  |  |  |   |  |  |  |  |  |  |  |  |
| P30-P37    | A8-A15         | ON                 |                 |                |                 |                |                 |                |                 |                |  |  |  |  |   |  |  |  |  |  |  |  |  |
|            |                | 16bit start:<br>ON |                 |                |                 |                |                 |                |                 |                |  |  |  |  |   |  |  |  |  |  |  |  |  |
| P40-P47    | A0-A7          | Built-in           |                 |                |                 |                | OFF             |                |                 |                |  |  |  |  |   |  |  |  |  |  |  |  |  |
| 1 10 1 11  | 710 711        | ROM                | 011             |                | 011             |                | <b>.</b> .      |                | 011             |                |  |  |  |  |   |  |  |  |  |  |  |  |  |
|            |                | start: OFF         | ON              |                | ON              |                |                 |                | ON              |                |  |  |  |  |   |  |  |  |  |  |  |  |  |
| PZ0        | RD             | ON                 |                 |                |                 |                |                 |                |                 |                |  |  |  |  |   |  |  |  |  |  |  |  |  |
| PZ1        | WR             |                    |                 |                |                 |                |                 |                |                 |                |  |  |  |  |   |  |  |  |  |  |  |  |  |
| PZ2        | HWR<br>R/W,    |                    |                 |                |                 |                |                 |                |                 |                |  |  |  |  |   |  |  |  |  |  |  |  |  |
| PZ3        | SRWE           | OFF (*1)           |                 |                |                 |                |                 |                |                 |                |  |  |  |  |   |  |  |  |  |  |  |  |  |
| P56        | -              |                    | _               |                | _               |                | _               |                | _               |                |  |  |  |  |   |  |  |  |  |  |  |  |  |
| P60        | CS0            |                    |                 |                |                 |                |                 |                |                 |                |  |  |  |  |   |  |  |  |  |  |  |  |  |
| P61        | CS1,           |                    |                 |                |                 |                |                 |                |                 |                |  |  |  |  |   |  |  |  |  |  |  |  |  |
| 101        | SDCS           |                    |                 |                |                 |                |                 |                |                 |                |  |  |  |  |   |  |  |  |  |  |  |  |  |
| P62        | CS2,<br>CS2A   |                    |                 |                |                 |                |                 |                |                 |                |  |  |  |  |   |  |  |  |  |  |  |  |  |
| P63        | CS3            |                    |                 |                |                 |                |                 |                |                 |                |  |  |  |  |   |  |  |  |  |  |  |  |  |
|            | EA24,          | ON                 |                 |                |                 |                |                 |                |                 |                |  |  |  |  |   |  |  |  |  |  |  |  |  |
| P64        | CS2B           | ON                 |                 | ON             |                 | ON             |                 | 055            |                 | ON             |  |  |  |  |   |  |  |  |  |  |  |  |  |
| P65        | EA25,          |                    |                 | ON             |                 | ON             |                 | OFF            |                 | ON             |  |  |  |  |   |  |  |  |  |  |  |  |  |
|            | CS2C           |                    |                 |                |                 |                |                 |                |                 |                |  |  |  |  |   |  |  |  |  |  |  |  |  |
| P66        | CS2D,<br>SRLB  |                    | ON              |                | ON              |                | OFF             |                | ON              |                |  |  |  |  |   |  |  |  |  |  |  |  |  |
|            | CS2E,          |                    |                 |                |                 |                |                 |                |                 |                |  |  |  |  |   |  |  |  |  |  |  |  |  |
| P67        | SRUB           |                    |                 |                |                 |                |                 |                |                 |                |  |  |  |  |   |  |  |  |  |  |  |  |  |
| P70        | SCK            |                    |                 |                |                 |                |                 |                |                 |                |  |  |  |  |   |  |  |  |  |  |  |  |  |
| D74        | SO,            |                    |                 |                |                 |                |                 |                |                 |                |  |  |  |  |   |  |  |  |  |  |  |  |  |
| P71        | SDA,<br>OPTTX0 |                    |                 |                |                 |                |                 |                |                 |                |  |  |  |  |   |  |  |  |  |  |  |  |  |
| P72        | SCL            |                    |                 |                |                 |                |                 |                |                 |                |  |  |  |  |   |  |  |  |  |  |  |  |  |
| P73        | CS2F           |                    |                 |                |                 |                |                 |                |                 |                |  |  |  |  |   |  |  |  |  |  |  |  |  |
| P74        | CS2G           |                    |                 |                |                 |                |                 |                |                 |                |  |  |  |  |   |  |  |  |  |  |  |  |  |
| P75        | CSEXA          |                    |                 |                |                 |                |                 |                |                 |                |  |  |  |  |   |  |  |  |  |  |  |  |  |
| P76        | -              | OFF                | _               |                | -               |                | _               |                | _               |                |  |  |  |  |   |  |  |  |  |  |  |  |  |
| P77        | VEECLK         | =                  |                 |                |                 |                |                 |                |                 |                |  |  |  |  |   |  |  |  |  |  |  |  |  |
| PA0<br>PA1 | KO0<br>KO1     |                    |                 |                |                 |                |                 |                |                 |                |  |  |  |  |   |  |  |  |  |  |  |  |  |
| PA1        | KO2            |                    |                 |                |                 |                |                 |                |                 |                |  |  |  |  |   |  |  |  |  |  |  |  |  |
| PA3        | KO3            |                    | ON              |                | ON              |                | OFF             |                | ON              |                |  |  |  |  |   |  |  |  |  |  |  |  |  |
| PA4        | KO4            |                    |                 |                |                 |                |                 |                |                 |                |  |  |  |  |   |  |  |  |  |  |  |  |  |
| PA5        | KO5            |                    |                 |                | 1               |                |                 |                |                 |                |  |  |  |  | - |  |  |  |  |  |  |  |  |
| PA6        | KO6            |                    |                 |                |                 |                |                 |                |                 |                |  |  |  |  |   |  |  |  |  |  |  |  |  |
| PA7        | KO7            |                    |                 |                |                 |                |                 |                |                 |                |  |  |  |  |   |  |  |  |  |  |  |  |  |

Output buffer state table (1/2)

|            |                   |            |          |          | Out        | put Buffer St |            |              |                  |          |
|------------|-------------------|------------|----------|----------|------------|---------------|------------|--------------|------------------|----------|
|            |                   |            | When th  | e CPU is |            |               |            | HALT mode    | (IDLE1/STC       | )P)      |
| Port       | Output            |            | oper     |          | In HALI mo | ode (IDLE2)   |            | n A (Note)   |                  | B (Note) |
| Name       | Function          | During     | When     | When     | When       | When          | When       | When         | When             | When     |
| Ivallie    | Name              | Reset      | Used as  | Used as  | Used as    | Used as       | Used as    | Used as      | Used as          | Used as  |
|            |                   |            | function | Output   | function   | Output        | function   | Output       | function         | Output   |
|            |                   |            | Pin      | Port     | Pin        | Port          | Pin        | Port         | Pin              | Port     |
| PB0        | TXD2              |            | ON       |          | ON         |               | OFF        |              | ON               |          |
| PB1        | TA1OUT            |            | 011      |          | 011        |               | 011        |              | 011              |          |
| PB3        | _                 |            | _        |          | _          |               | _          |              | _                |          |
| PB4        | _                 |            |          |          |            |               |            |              |                  |          |
| PB5        | TA3OUT            |            |          |          |            |               |            |              |                  |          |
| PB6        | TB0OUT0           | OFF        | ON       |          | ON         |               | OFF        |              | ON               |          |
| PC0        | TXD0              | <b>.</b> . |          |          |            |               |            |              |                  |          |
| PC1        | -                 |            | _        |          | _          |               | _          |              | _                |          |
| PC2        | SCLK0             |            | ON       |          | ON         |               | OFF        |              | ON               |          |
| PC3        | TXD1              |            |          |          |            |               |            |              |                  |          |
| PC4        | _                 |            | _        |          | _          |               | _          |              | _                |          |
| PC5        | SCLK1             |            |          |          |            |               |            |              |                  |          |
| PD0        | D1BSCP            |            |          |          |            |               |            |              |                  |          |
| PD1        | D2BLP             |            |          |          |            |               |            |              |                  |          |
| PD2        | D3BFR             |            |          | ON       |            | ON            |            | OFF          |                  | ON       |
| PD3        | DLEBCD            | ON         |          |          |            |               |            |              |                  |          |
| PD4        | DOFFB             |            |          |          |            |               |            |              |                  |          |
| PD6        | ALARM,            |            |          |          |            |               | ٥٢٢        |              |                  |          |
| PD7        | MLDALM            |            |          |          |            |               | OFF        |              |                  |          |
| PE0-7      | MLDALM<br>LD0-LD7 | OFF        |          |          |            |               |            |              | ON               |          |
| PE0-7      | SDRAS             | UFF        | ON       |          | ON         |               |            |              | ON               |          |
| PF0<br>PF1 | SDCAS             |            |          |          |            |               |            |              |                  |          |
| PF2        | SDWE              |            |          |          |            |               |            |              |                  |          |
| PF3        | SDLDQM            |            |          |          |            |               |            |              |                  |          |
| PF4        | SDUDQM            | _          |          |          |            |               |            |              |                  |          |
| - ' ' -    | SECERIVI          | ON         |          |          |            |               | ON in self |              |                  |          |
| PF5        | SDCKE             |            |          |          |            |               | refresh    |              |                  |          |
|            |                   |            |          |          |            |               | cycle      |              |                  |          |
| PF6        | SDCLK             |            |          |          |            |               | ÓFF        |              |                  |          |
| X2, XT2    | _                 |            |          | -        | 1          | -             |            | LE1: ON, STO | P: output "H" le | evel     |

ON: The buffer is always turned on.

OFF: The buffer is always turned off.

-: No applicable

Note: Condition A/B are as follows.

| SYSCR2 re     | egister setting   | HALT        | mode        |  |
|---------------|-------------------|-------------|-------------|--|
| <drve></drve> | <seldrv></seldrv> | IDLE1       | STOP        |  |
| 0             | 0                 | Condition A | Condition A |  |
| 0             | 1                 |             | Condition A |  |
| 1             | 0                 | Condition B | Condition B |  |
| 1             | 1                 |             | Condition B |  |

# 3.4 Interrupts

Interrupts are controlled by the CPU interrupt mask register SR<IFF2:0> and by the built-in interrupt controller.

The TMP91C820A has a total of 43 interrupts divided into the following 5 types:

- Interrupts generated by CPU: 9 sources (Software interrupts, illegal instruction interrupt)
- Internal interrupts: 28 sources
- Interrupts on external pins (NMI and INTO to INT3, INTKEY): 6 sources

A (Fixed) individual interrupt vector number is assigned to each interrupt.

One of six (Variable) priority levels can be assigned to each maskable interrupt.

The priority level of non-maskable interrupts is fixed at 7, the highest level.

When an interrupt is generated, the interrupt controller sends the piority of that interrupt to the CPU. If multiple interrupts are generated simultaneously, the interrupt controller sends the interrupt with the highest priority to the CPU. (The highest priority possible is level 7, used for non-maskable interrupts.)

The CPU compares the priority level of the interrupt with the value of the CPU interrupt mask register <IFF2:0>. If the priority level of the interrupt is higher than the value of the interrupt mask register, the CPU accepts the interrupt.

However, software interrupts and illegal instruction interrupts generated by the CPU are processed without comparison with the <IFF2:0> value.

The interrupt mask register <IFF2:0> value can be updated using the value of the EI instruction (Executing EI num sets the content of <IFF2:0> to num). For example, specifying EI3 enables the acceptance of maskable interrupts whose priority level set in the interrupt controller is 3 or higher, and enables the acceptance of non-maskable interrupts. However, if EI or EI0 is specified, maskable interrupts with a priority level of 1 or higher and non-maskable interrupts are accepted (Operationally identical to "EI" 1).

Operationally, the DI instruction (<IFF2:0> is 7) is identical to the EI 7 instruction, but as the priority level of maskable interrupts is 1 to 6, the DI instruction is used to dasable maskable interrupt. The EI instruction is vaild immediately after execution begins. (With TLCS-90, the EI instruction is vaild after execution of the instruction following the EI insutruction.)

In addition to the general-purpose interrupt processing mode described above, TLCS-900/L1 interrupts have a micro DMA processing mode as well.

Because the CPU transfers (Byte transfer, or 4-byte transfer) automatically in micro DMA mode, this mode can be used for speeding up interrupt processing, such as transferring data to I/O. TMP91C820A also has a micro DMA soft start function for requesting micro DMA processing by software not by interrupt.

Figure 3.4.1 shows the overall interrupt processing flow.



Figure 3.4.1 Interrupt and Micro DMA Processing Sequence

# 3.4.1 General-purpose Interrupt Processing

When the CPU accepts an interrupt, it usually performs the following sequence of operations. However, in the case of software interrupts and illegal instruction interrupts generated by the CPU, the CPU skips steps a and c and executes only steps b, d and e.

- a. The CPU reads the interrupt vector from the interrupt controller.
  - If there are simultaneous interrupts set to same level, the interrupt controller generates an interrupt vector in accordance with the default priority and clears the interrupt request.
  - (The default priority is already fixed for each interrupt: The smaller the vector value, the higher the priority level.)
- b. The CPU pushes the program counter (PC) and status register (SR) onto the top of the stack (Pointed to by XSP).
- c. The CPU sets the value of the CPU's interrupt mask register <IFF2:0> to the priority level for the accepted interrupt plus 1. However, if the priority level for the accepted interrupt is 7, the register's value is set to 7.
- d. The CPU increments the interrupt nesting counter INTNEST by 1.
- e. The CPU jumps to the address indicated by the data at address FFFF00H + interrupt vector, and starts the interrupt processing routine.

The above processing time is 18 states (1.00  $\mu$ s at 36 MHz) as the best case (16-bit data bus width and 0 waits).

When the CPU completed the interrupt processing, use the RETI instruction to return to the main routine. RETI restores the contents of the program counter and the status register from the stack and decrements the interrupt nesting counter INTNEST by 1.

Non-maskable interrupts cannot be disabled by a user program. Maskable interrupts, however, can be enabled or disabled by a user program. A program can set the priority level for each interrupt source. (A priority level setting of 0 or 7 will disable an interrupt request.)

If an interrupt request is received for an interrupt with a priority level equal to or greater than the value set in the CPU interrupt mask register <IFF2:0>, the CPU will accept the interrupt. The CPU interrupt mask register <IFF2:0> is then set to the value of the priority level for the accepted interrupt plus 1.

If, during interrupt processing, an interrupt is generated with a higher level than the interrupt begin currently processed, or if, during non-maskable interrupt processing, a non-maskable interrupt request is generated from another source, the CPU suspends the currently processing routine and accepts the later interrupt. Then, after the CPU finished processing the later interrupt, the CPU returns to the interrupt it previously suspended and resumes processing.

If the CPU receives a request for another interrupt while performing processing steps a to e, the second interrupt is sampled immediately after execution of the first instruction for its interrupt processing routine. Specifying DI as the start instruction disables maskable interrupt nesting. (Note: In the 900 and 900/L, sampling is performed before execution of the start instruction.)

A reset initializes the interrupt mask register <IFF2:0> to 111, disabling all maskable interrupts.

Table 3.4.1 shows the TMP91C820A interrupt vectors and micro DMA start vectors. FFFF00H to FFFFFFH (256 bytes) is designated as the interrupt vector area.

Table 3.4.1 TMP91C820A Interrupt Vectors and Micro DMA Start Vectors

| Default<br>Priority | Туре     | Interrupt Source and Source of Micro DMA<br>Request | Vector<br>Value (V) | Vector<br>Reference<br>Address | Micro<br>DMA<br>Start<br>Vector |
|---------------------|----------|-----------------------------------------------------|---------------------|--------------------------------|---------------------------------|
| 1                   |          | "Reset" or "SWI0" instruction                       | 0000H               | FFFF00H                        | _                               |
| 2                   |          | "SWI1" instruction                                  | 0004H               | FFFF04H                        | _                               |
| 3                   | ]        | INTUNDEF: Illegal instruction or "SWI2" instruction | 0008H               | FFFF08H                        | _                               |
| 4                   | ]        | "SWI3" instruction                                  | 000CH               | FFFF0CH                        | _                               |
| 5                   | Non-     | "SWI4" instruction                                  | 0010H               | FFFF10H                        | _                               |
| 6                   | maskable | "SWI5" instruction                                  | 0014H               | FFFF14H                        | _                               |
| 7                   | ]        | "SWI6" instruction                                  | 0018H               | FFFF18H                        | _                               |
| 8                   |          | "SWI7" instruction                                  | 001CH               | FFFF1CH                        | _                               |
| 9                   |          | NMI pin                                             | 0020H               | FFFF20H                        | _                               |
| 10                  |          | INTWD: Watchdog timer                               | 0024H               | FFFF24H                        | _                               |
| _                   |          | (Micro DMA)                                         | _                   | _                              | _                               |
| 11                  |          | INTO pin                                            | 0028H               | FFFF28H                        | 0AH                             |
| 12                  | 1        | INT1 pin                                            | 002CH               | FFFF2CH                        | 0BH                             |
| 13                  | 1        | INT2 pin                                            | 0030H               | FFFF30H                        | 0CH                             |
| 14                  | 1        | INT3 pin                                            | 0034H               | FFFF34H                        | 0DH                             |
| 15                  |          | INTALM0: ALM0 (8 kHz)                               | 0038H               | FFFF38H                        | 0EH                             |
| 16                  |          | INTALM1: ALM1 (512 Hz)                              | 003CH               | FFFF3CH                        | 0FH                             |
| 17                  |          | INTALM2: ALM2 (64 Hz)                               | 0040H               | FFFF40H                        | 10H                             |
| 18                  |          | INTALM3: ALM3 (2 Hz)                                | 0044H               | FFFF44H                        | 11H                             |
| 19                  |          | INTALM4: ALM4 (1 Hz)                                | 0048H               | FFFF48H                        | 12H                             |
| 20                  |          | INTTA0: 8-bit timer 0                               | 004CH               | FFFF4CH                        | 13H                             |
| 21                  |          | INTTA1: 8-bit timer 1                               | 0050H               | FFFF50H                        | 14H                             |
| 22                  |          | INTTA2: 8-bit timer 2                               | 0054H               | FFFF54H                        | 15H                             |
| 23                  |          | INTTA3: 8-bit timer 3                               | 0058H               | FFFF58H                        | 16H                             |
| 24                  |          | INTRX0: Serial receives (Channel 0)                 | 005CH               | FFFF5CH                        | 17H                             |
| 25                  |          | INTTX0: Serial transmission (Channel 0)             | 0060H               | FFFF60H                        | 18H                             |
| 26                  |          | INTRX1: Serial receives (Channel 1)                 | 0064H               | FFFF64H                        | 19H                             |
| 27                  |          | INTTX1: Serial transmission (Channel 1)             | 0068H               | FFFF68H                        | 1AH                             |
| 28                  |          | INTAD: AD conversion end                            | 006CH               | FFFF6CH                        | 1BH                             |
| 29                  | Maskable | INTKEY: Key-on wakeup                               | 0070H               | FFFF70H                        | 1CH                             |
| 30                  |          | INTRTC: RTC (Alarm interrupt)                       | 0074H               | FFFF74H                        | 1DH                             |
| 31                  |          | INTSBI: SBI interrupt                               | 0078H               | FFFF78H                        | 1EH                             |
| 32                  | 1        | INTLCD: LCDC/LP pin                                 | 007CH               | FFFF7CH                        | 1FH                             |
| 33                  | 1        | INTP0: Protect 0 (WR to special SFR)                | 0080H               | FFFF80H                        | 20H                             |
| 34                  | 1        | INTP1: Protect 1 (WR to ROM)                        | 0084H               | FFFF84H                        | 21H                             |
| 35                  | 1        | INTTC0: Micro DMA end (Channel 0)                   | 0088H               | FFFF88H                        | _                               |
| 36                  | 1        | INTTC1: Micro DMA end (Channel 1)                   | 008CH               | FFFF8CH                        | _                               |
| 37                  | 1        | INTTC2: Micro DMA end (Channel 2)                   | 0090H               | FFFF90H                        | _                               |
| 38                  | 1        | INTTC3: Micro DMA end (Channel 3)                   | 0094H               | FFFF94H                        | _                               |
| 39                  | 1        | Reserved                                            | -                   | -                              | _                               |
| 40                  | 1        | Reserved                                            | _                   | _                              | _                               |
| 41                  | 1        | Reserved                                            | _                   | _                              | _                               |
| 42                  | 1        | INTRX2: Serial receive (Channel 2)                  | 00A4H               | FFFFA4H                        | 29H                             |
| 43                  | 1        | INTTX2: Serial transmission (Channel 2)             | 00A8H               | FFFFA8H                        | 2AH                             |
| 44                  | 1        | INTTB00: 16-bit timer 0 (TB0RG0)                    | 00ACH               | FFFFACH                        | 2BH                             |
| 45                  | 1        | INTTB01: 16-bit timer 1 (TB0RG1)                    | 00B0H               | FFFFB0H                        | 2CH                             |
|                     | 1        | (Reserved)                                          | 00B4H               | FFFFB4H                        | _                               |
|                     |          | to                                                  | to                  | to                             | to                              |
|                     |          | (Reserved)                                          | 00FCH               | FFFFFCH                        | -                               |

# 3.4.2 Micro DMA Processing

In addition to general-purpose interrupt processing, the TMP91C820A supprots a micro DMA function. Interrupt requests set by micro DMA perform micro DMA processing at the highest priority level for maskable interrupts (Level 6), regardless of the priority level of the particular interrupt source.

Because the micro DMA function has been implemented with the cooperative operation of CPU, when CPU is a state of standby by HALT instruction, the requirement of micro DMA will be ignored (Pending).

### (1) Micro DMA operation

When an interrupt request is generated by an interrupt source specified by the micro DMA start vector register, the micro DMA triggers a micro DMA request to the CPU at interrupt priority level 6 and starts processing the request. The four micro DMA channels allow micro DMA processing to be set for up to four types of interrupts at any one time.

When micro DMA is accepted, the interrupt request flip-flop assigned to that channel is cleared. The data are automatically transferred from the transfer source address to the transfer destination address set in the control register, and the transfer counter is decremented by 1. If the decremented counter reads other than 0, DMA processing ends with no change in the value of the micro DMA start vector register. If the decremented reading is 0, the micro DMA transfer end interrupt (INTTC0 to INTTC3) passes from the CPU to the interrupt controller. In addition, the micro DMA start vector register is cleared to 0, the next micro DMA is disabled and micro DMA processing completes.

If a micro DMA request is set for more than one channel at a time, the priority is not based on the interrupt priority level but on the channel number: the smaller the channel number the higher the priority (Channel 0 (High)  $\rightarrow$  Channel 3 (Low)).

If an interrupt request is triggered for the interrupt source in use during the interval between the clearing of the micro DMA start vector and the next setting, general-purpose interrupt processing executes at the interrupt level set. Therefore, if only using the interrupt for starting the micro DMA (Not using the interrupts as a general-purpose interrupt), first set the interrupts level to 0 (Interrupt requests disabled).

If using micro DMA and general-purpose interrupts together as described above, first set the level of the interrupt used to start micro DMA processing lower than all the other interrupt levels. In this case, the cause of general interrupt is limited to the edge interrupt. (Note)

As with other maskable interrupts, the priority of the micro DMA transfer end interrupts is determined by the interrupt level and by the default priority.

Note: If the priority level of micro DMA is set higher than that of other interrupts, CPU operates as follows. In case INTxxx interrupt is generated first and then INTyyy interrupt is generated between checking "Interrupt specified by micro DMA start vector" (in the Figure 3.4.1) and reading interrupt vector with setting below. The vector shifts to that of INTyyy at the time.

This is because the priority level of INTyyy is higher than that of INTxxx.

In the interrupt routine, CPU reads the vector of INTyyy because cheking of micro DMA has finished. And INTyyy is generated regardless of transfer counter of micro DMA.

INTxxx: level 1 without micro DMA INTyyy: level 6 with micro DMA

While the register for setting the transfer source/transfer destination addresses is a 32-bit control register, this register can only effectively output 24-bit addresses. Accordingly, micro DMA can access 16 Mbytes (The upper 8 bits of the 32 bits are not valid).

Three micro DMA transfer modes are supported: 1-byte transfer, 2-byte (One-word) transfer, and 4-byte transfer. After a transfer in any mode, the transfer source/destination addresses are incremented, decremented, or remain unchanged.

This simplifies the transfer of data from I/O to memory, from memory to I/O, and from I/O to I/O. For details of the transfer modes, see 3.4.2 (4) "Detailed description of the transfer mode register". As the transfer counter is a 16-bit counter, micro DMA processing can be set for up to 65536 times per interrupt source. (The micro DMA processing count is maximized when the transfer counter initial value is set to 0000H.)

Micro DMA processing can be started by the 31 interrupts shown in the micro DMA start vectors of Table 3.4.1 and by the micro DMA soft start, making a total of 32 interrupts.

Figure 3.4.2 shows the word transfer micro DMA cycle in transfer destination address INC mode (except for counter mode, the same as for other modes).

(The conditions for this cycle are based on an external 16-bit bus, 0 waits, transfer source/transfer destination addresses both even-numberd values).



Figure 3.4.2 Timing for Micro DMA Cycle

States 1 to 3: Instruction fetch cycle (Gets next address code).

If three or more instruction codes are inserted in the instruction queue buffer, this cycle becomes a dummy cycle.

States 4 to 5: Micro DMA read cycle.

State 6: Dummy cycle (The address bus remains unchanged from state 5).

States 7 to 8: Micro DMA write cycle.

Note 1: If the source address area is an 8-bit bus, it is incremented by two states.

If the source address area is a 16-bit bus and the address starts from an odd number, it is incremented by two states.

Note 2: If the destination address area is an 8-bit bus, it is incremented by two states.

If the destination address area is a 16-bit bus and the address starts from an odd number, it is incremented by two states.

### (2) Soft start function

In addition to starting the micro DMA function by interrupts, TMP91C820A includes a micro DMA software start function that starts micro DMA on the generation of the write cycle to the DMAR register.

Writing 1 to each bit of DMAR register causes micro DMA once (If write "0" to each bit, micro DMA doesn't operate). At the end of transfer, the corresponding bit of the DMAR register which support the end channel are automatically cleared to 0.

Only one channel can be set for DMA request at once. (Do not write 1 to plural bits)

When writing again 1 to the DMAR register, check whether the bit is 0 before writing 1. If read "1", micro DMA transfer isn't started yet.

When a burst is specified by DMAB register, data is continuously transferred until the value in the micro DMA transfer counter is 0 after start up of the micro DMA. If execute soft start during micro DMA transfer by interrupt source, micro DMA transfer counter doesn't change. Don't use Read-modify-write instruction to avoid writing to other bits by mistake.

| Symbol | Name           | Address   | 7 | 6 | 5 | 4 | 3     | 2     | 1      | 0     |
|--------|----------------|-----------|---|---|---|---|-------|-------|--------|-------|
|        |                |           |   |   |   |   |       | DMA r | equest |       |
| DMAR   | DMA<br>request | 89H       |   |   |   |   | DMAR3 | DMAR2 | DMAR1  | DMAR0 |
| DIVIAR | register       | (Prohibit |   |   |   |   |       | R     | W      |       |
|        |                | RMW)      |   |   |   |   | 0     | 0     | 0      | 0     |

### (3) Transfer control registers

The transfer source address and the transfer destination address are set in the following registers. An instruction of the form "LDC cr, r" can be used to set these registers.



(4) Detailed description of the transfer mode register

DMAM0 to 8 bits — 8 bits — Mode

Note: When setting a value in this register, write 0 to the upper three bits.

|                |     |          |                                                          |                                                                                                                                           | Ī                              |                                             |
|----------------|-----|----------|----------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------|---------------------------------------------|
|                |     |          | Number of<br>Transfer Bytes                              | Mode Description                                                                                                                          | Number of Execution States (*) | Minimum<br>Execution Time<br>at fc = 36 MHz |
| 000<br>(Fixed) | 000 | 00       | Byte transfer                                            | $\label{eq:local_continuity}  \mbox{Transfer destination address INC mode} \\l/O to memory \\ (\mbox{DMADn+}) \leftarrow (\mbox{DMASn}) $ | 8 states                       | 444 ns                                      |
|                |     | 01       | Word transfer                                            | DMACn ← DMACn − 1                                                                                                                         |                                |                                             |
|                |     | 10       | 4-byte transfer                                          | If DMACn = 0, then INTTCn is generated.                                                                                                   | 12 sates                       | 667 ns                                      |
|                | 001 | 00       | Byte transfer                                            | Transfer destination address DEC modeI/O to memory                                                                                        | 8 states                       | 444 ns                                      |
|                |     | 01       | Word transfer                                            | (DMADn-) ← (DMASn)  DMACn ← DMACn - 1  If DMACn = 0, then INTTCn is generated.                                                            | 12 sates                       | 667 ns                                      |
|                | 010 | 00       | 4-byte transfer  Byte transfer                           | Transfer source address INC modeMemory to I/O                                                                                             | 8 states                       | 444 ns                                      |
|                |     | 01<br>10 | Word transfer                                            | (DMADn) ← (DMASn+)  DMACn ← DMACn − 1  If DMACn = 0, then INTTCn is generated.                                                            | 12 sates                       | 667 ns                                      |
|                | 011 | 00       | 4-byte transfer  Byte transfer                           | Transfer source address DEC modeMemory to I/O                                                                                             | 8 states                       | 444 ns                                      |
|                |     | 01       | Word transfer                                            | (DMADn) ← (DMASn–)  DMACn ← DMACn – 1  If DMACn = 0, then INTTCn is generated.                                                            | 12 sates                       | 667 ns                                      |
|                | 100 | 00       | 4-byte transfer  Byte transfer                           | Fixed address mode                                                                                                                        | 8 states                       | 444 ns                                      |
|                |     | 01<br>10 | Word transfer 4-byte transfer                            | (DMADn) ← (DMASn–)  DMACn ← DMACn – 1  If DMACn = 0, then INTTCn is generated.                                                            | 12 sates                       | 667 ns                                      |
|                | 101 | 00       | Counter mode<br>For co<br>DMASn ← DMASn<br>DMACn ← DMACn | ounting number of times interrupt is generated.<br>+ 1                                                                                    | 5 sates                        | 278 ns                                      |

(\*) For external 16-bit bus, 0 waits, word/4-byte transfer mode, transfer source/transfer destination addresses both have even-numbered values.

Note: n: Corresponding micro DMA channels 0 to 3.

DMADn+/DMASn+: Post increment (Increments register value after transfer).

DMADn-/DMASn-: Post decrement (Decrements register value after transfer).

The I/Os in the table mean fixed address; memory means increment and decrement addresses.

Do not use undefined code, that is, codes other than those listed above for the transfer mode register.

# 3.4.3 Interrupt Controller Operation

The block diagram in Figure 3.4.3 shows the interrupt circuits. The left-hand side of the diagram shows the interrupt controller circuit. The right-hand side shows the CPU interrupt request signal circuit and the halt release circuit.

For each of the 36 interrupt channels there is an interrupt request flag (Consisting of a flip-flop), an interrupt priority setting register and a micro DMA start vector register. The interrupt request flag latches interrupt requests from the peripherals. The flag is cleared to zero in the following cases: when reset occurs, when the CPU reads the channel vector of an interrupt it has received, when the CPU receives a micro DMA request (When micro DMA is set), when the micro DMA burst transfer is terminated, and when an instruction that clears the interrupt for that channel is executed (by writing 0 to the clear bit in the interrupt priority setting register).

An interrupt priority can be set independently for each interrupt source by writing the priority to the interrupt priority setting register (e.g., INTE0AD or INTE12). Six interrupt priorities levels (1 to 6) are provided. Setting an interrupt source's priority level to 0 (or 7) disables interrupt requests from that source. The priority of non-maskable interrupts (NMI pin interrupts and watchdog timer interrupts) is fixed at 7. If interrupt request with the same level are generated at the same time, the default priority (The interrupt with the lowest priority or, in other words, the interrupt with the lowest vector value) is used to determine which interrupt request is accepted first.

The 3rd and 7th bits of the interrupt priority setting register indicate the state of the interrupt request flag and thus whether an interrupt request for a given channel has occurred.

The interrupt controller sends the interrupt request with the highest priority among the simulateous interrupts and its vector address to the CPU. The CPU compares the priority value <IFF2:0> et in the status register by the interrupt request signal with the priority value set; if the latter is higher, the interrupt is accepted. Then the CPU sets a value higher than the priority value by 1 in the CPU SR<IFF2:0>. Interrupt request where the priority value equals or is higher than the set value are accepted simultaneously during the previous interrupt routine.

When interrupt processing is completed (after execution of the RETI instruction), the CPU restores the priority value saved in the stack before the interrupt was generated to the CPU SR<IFF2:0>. The interrupt controller also has four registers used to store the micro DMA start vector. Writing the start vector of the interrupt source for the micro DMA processing (See Table 3.4.1), enables the corresponding interrupt to be processed by micro DMA processing. The values must be set in the micro DMA parameter register (e.g., DMAS and DMAD) prior to the micro DMA processing.



Figure 3.4.3 Block Diagram of Interrupt Controller

**TOSHIBA** 

# (1) Interrupt level setting registers

| Symbol     | Name             | Address               | 7     | 6              | ţ            | 5           | 4                                  |                                    | 3                                                              | 3                                     | 2              | 1      | 0         |     |     |     |     |     |     |     |     |     |     |   |  |    |  |  |  |   |  |  |     |  |
|------------|------------------|-----------------------|-------|----------------|--------------|-------------|------------------------------------|------------------------------------|----------------------------------------------------------------|---------------------------------------|----------------|--------|-----------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|---|--|----|--|--|--|---|--|--|-----|--|
|            |                  |                       |       |                | INTAD        |             |                                    |                                    |                                                                |                                       | IN             | T0     |           |     |     |     |     |     |     |     |     |     |     |   |  |    |  |  |  |   |  |  |     |  |
| INITEGAD   | INTO and         | 0011                  | IADO  | IADM           | 12 IAC       | M1          | IADN                               | 10                                 | 10                                                             | С                                     | I0M2           | IOM1   | IOMO      |     |     |     |     |     |     |     |     |     |     |   |  |    |  |  |  |   |  |  |     |  |
| INTE0AD    | INTAD<br>enable  | 90H                   | R     |                | R/           | W           |                                    |                                    | F                                                              | ₹                                     |                | R/W    | •         |     |     |     |     |     |     |     |     |     |     |   |  |    |  |  |  |   |  |  |     |  |
|            | Chable           |                       | 0     | 0              | (            | )           | 0                                  |                                    | (                                                              | )                                     | 0              | 0      | 0         |     |     |     |     |     |     |     |     |     |     |   |  |    |  |  |  |   |  |  |     |  |
|            |                  |                       |       | II.            | INT2         |             |                                    |                                    |                                                                |                                       | IN             | T1     |           |     |     |     |     |     |     |     |     |     |     |   |  |    |  |  |  |   |  |  |     |  |
|            | INT1 and         |                       | I2C   | I2M2           | 2 121        | <b>V</b> 11 | I2M0                               | 0                                  | l1                                                             | С                                     | I1M2           | I1M1   | I1M0      |     |     |     |     |     |     |     |     |     |     |   |  |    |  |  |  |   |  |  |     |  |
| INTE12     | INT2<br>enable   | 91H                   | R     |                | R/           | W           |                                    |                                    | F                                                              | ?                                     |                | R/W    |           |     |     |     |     |     |     |     |     |     |     |   |  |    |  |  |  |   |  |  |     |  |
|            | enable           |                       | 0     | 0              | (            | )           | 0                                  |                                    | (                                                              | )                                     | 0              | 0      | 0         |     |     |     |     |     |     |     |     |     |     |   |  |    |  |  |  |   |  |  |     |  |
|            |                  |                       |       |                | NTALM4       |             |                                    |                                    |                                                                |                                       | IN             | T3     | I.        |     |     |     |     |     |     |     |     |     |     |   |  |    |  |  |  |   |  |  |     |  |
|            | INT3 and         |                       | IA4C  | IA4M           | 12 IA4       | M1          | IA4M                               | 10                                 | 13                                                             | С                                     | I3M2           | I3M1   | I3M0      |     |     |     |     |     |     |     |     |     |     |   |  |    |  |  |  |   |  |  |     |  |
| INTE3ALM4  | INTALM4          | 92H                   | R     |                | R/           | W           |                                    |                                    | F                                                              | ₹                                     |                | R/W    |           |     |     |     |     |     |     |     |     |     |     |   |  |    |  |  |  |   |  |  |     |  |
|            | enable           |                       | 0     | 0              | (            | )           | 0                                  |                                    | (                                                              | )                                     | 0              | 0      | 0         |     |     |     |     |     |     |     |     |     |     |   |  |    |  |  |  |   |  |  |     |  |
|            | INTALM0          |                       |       | l              | NTALM1       |             |                                    |                                    |                                                                |                                       | INTA           | ALM0   | I         |     |     |     |     |     |     |     |     |     |     |   |  |    |  |  |  |   |  |  |     |  |
|            | and              |                       | IA1C  | IA1M           | 12 IA1       | M1          | IA1M                               | 10                                 | IA                                                             | C                                     | IA0M2          | IA0M1  | IA0M0     |     |     |     |     |     |     |     |     |     |     |   |  |    |  |  |  |   |  |  |     |  |
| INTEALM01  | INTALM1          | 93H                   | R     |                | R/           | W           |                                    |                                    | F                                                              | ₹                                     |                | R/W    | I         |     |     |     |     |     |     |     |     |     |     |   |  |    |  |  |  |   |  |  |     |  |
|            | enable           |                       |       | 0              | (            | )           | 0                                  |                                    | (                                                              | )                                     | 0              | 0      | 0         |     |     |     |     |     |     |     |     |     |     |   |  |    |  |  |  |   |  |  |     |  |
|            | INTALM2          |                       |       |                | NTALM3       |             |                                    |                                    |                                                                |                                       | INTA           | LM2    | I         |     |     |     |     |     |     |     |     |     |     |   |  |    |  |  |  |   |  |  |     |  |
|            | and              |                       | IA3C  | IA3M           | 12 IA3       | M1          | IA3M                               | 10                                 | IA2                                                            | 2C                                    | IA2M2          | IA2M1  | IA2M0     |     |     |     |     |     |     |     |     |     |     |   |  |    |  |  |  |   |  |  |     |  |
| INTEALM23  | LM23 INTALM3 94H |                       | R     |                | R/           | W           |                                    |                                    | F                                                              | ₹                                     |                | R/W    | I         |     |     |     |     |     |     |     |     |     |     |   |  |    |  |  |  |   |  |  |     |  |
|            | enable           |                       | 0     | 0              | (            | )           | 0                                  |                                    | (                                                              | )                                     | 0              | 0      | 0         |     |     |     |     |     |     |     |     |     |     |   |  |    |  |  |  |   |  |  |     |  |
|            | INITTAG          | NTTA0                 |       | INTTA1 (TMRA1) |              |             |                                    | INTTA0 (TMRA0)                     |                                                                |                                       |                |        |           |     |     |     |     |     |     |     |     |     |     |   |  |    |  |  |  |   |  |  |     |  |
| INTETA01 a | and              |                       | ITA10 |                | <u> </u>     |             | ITA1N                              | MO                                 | ITA                                                            | 0C                                    | ITA0M2         | ITA0M1 | ITA0M0    |     |     |     |     |     |     |     |     |     |     |   |  |    |  |  |  |   |  |  |     |  |
|            | INTTA1           | 95H                   | R     |                | R/           | W           |                                    |                                    | F                                                              |                                       |                | R/W    |           |     |     |     |     |     |     |     |     |     |     |   |  |    |  |  |  |   |  |  |     |  |
|            | enable           |                       | 0     | 0              | - 1          | )           | 0                                  |                                    | (                                                              |                                       | 0              | 0      | 0         |     |     |     |     |     |     |     |     |     |     |   |  |    |  |  |  |   |  |  |     |  |
|            | INITTAG          |                       |       |                | A3 (TMR      |             |                                    |                                    |                                                                |                                       | INTTA2         | _      |           |     |     |     |     |     |     |     |     |     |     |   |  |    |  |  |  |   |  |  |     |  |
|            | INTTA2<br>and    |                       | ITA30 | 1              | <del>i</del> |             | ITA3N                              | MO.                                | ITA                                                            | 2C                                    | ITA2M2         | ITA2M1 | ITA2M0    |     |     |     |     |     |     |     |     |     |     |   |  |    |  |  |  |   |  |  |     |  |
| INTETA23   | INTTA3           | 96H -                 | 96H - | 96H -          | 96H -        | 96H -       | 96H                                | 96H                                | 96H                                                            | 96H                                   | 96H            | 96H    | 96H       | 96H | 96H | 96H | 96H | 96H | 96H | 96H | 96H | 96H | 96H | R |  | R/ |  |  |  | F |  |  | R/W |  |
|            | enable           |                       |       |                |              |             |                                    | 0                                  | 0                                                              |                                       | )              | 0      |           | (   |     | 0   | 0   | 0   |     |     |     |     |     |   |  |    |  |  |  |   |  |  |     |  |
|            | INITOTO          |                       |       |                | INTKEY       | •           |                                    |                                    |                                                                |                                       | INTI           | -      |           |     |     |     |     |     |     |     |     |     |     |   |  |    |  |  |  |   |  |  |     |  |
|            | INTRTC<br>and    |                       | IKC   | IKM            | — t          | VI1         | IKM                                | 0                                  | IR                                                             | С                                     | IRM2           | IRM1   | IRM0      |     |     |     |     |     |     |     |     |     |     |   |  |    |  |  |  |   |  |  |     |  |
| INTERTCKEY | INTKEY           | 97H                   | R     |                |              |             |                                    | _                                  | F                                                              |                                       |                | R/W    |           |     |     |     |     |     |     |     |     |     |     |   |  |    |  |  |  |   |  |  |     |  |
|            | enable           |                       | 0     | 0              | R/W<br>0     |             | 0                                  |                                    | . (                                                            |                                       | 0              | 0      | 0         |     |     |     |     |     |     |     |     |     |     |   |  |    |  |  |  |   |  |  |     |  |
|            |                  |                       |       |                | INTTX0       | ,           | O                                  |                                    |                                                                |                                       | INT            |        |           |     |     |     |     |     |     |     |     |     |     |   |  |    |  |  |  |   |  |  |     |  |
|            | Interrupt        |                       | ITX00 | 1              |              | )M1         | ITXON                              | MO.                                | IRX                                                            | nC.                                   | IRX0M2         | IRX0M1 | IRX0M0    |     |     |     |     |     |     |     |     |     |     |   |  |    |  |  |  |   |  |  |     |  |
| INTES0     | enable           | 98H                   | R     | 117.01.        | R/           |             | 117(01)                            | •0                                 | F                                                              |                                       | HOTOME         | R/W    | 110101110 |     |     |     |     |     |     |     |     |     |     |   |  |    |  |  |  |   |  |  |     |  |
|            | serial 0         |                       | 0     | 0              | (            |             | 0                                  |                                    | (                                                              |                                       | 0              | 0      | 0         |     |     |     |     |     |     |     |     |     |     |   |  |    |  |  |  |   |  |  |     |  |
|            |                  |                       | Ť     |                |              |             |                                    |                                    |                                                                |                                       | · ·            | , ,    | , ,       |     |     |     |     |     |     |     |     |     |     |   |  |    |  |  |  |   |  |  |     |  |
|            |                  |                       |       |                |              |             |                                    |                                    |                                                                |                                       |                |        |           |     |     |     |     |     |     |     |     |     |     |   |  |    |  |  |  |   |  |  |     |  |
| Interru    | ipt request f    | flag <del>← − −</del> | •     |                | <u> </u>     |             |                                    |                                    |                                                                |                                       |                |        |           |     |     |     |     |     |     |     |     |     |     |   |  |    |  |  |  |   |  |  |     |  |
|            |                  |                       |       |                |              |             |                                    |                                    |                                                                |                                       |                |        |           |     |     |     |     |     |     |     |     |     |     |   |  |    |  |  |  |   |  |  |     |  |
|            |                  |                       | •     | lxxM2 lxxM1 lx |              |             | xM0                                |                                    |                                                                | Fu                                    | nction (W      | rite)  |           |     |     |     |     |     |     |     |     |     |     |   |  |    |  |  |  |   |  |  |     |  |
|            |                  |                       |       | 0 0            |              |             | 0                                  |                                    |                                                                | · · · · · · · · · · · · · · · · · · · |                |        |           |     |     |     |     |     |     |     |     |     |     |   |  |    |  |  |  |   |  |  |     |  |
|            |                  |                       |       | 0              | 0            |             | 1                                  |                                    | Disables interrupt requests Sets interrupt priority level to 1 |                                       |                |        |           |     |     |     |     |     |     |     |     |     |     |   |  |    |  |  |  |   |  |  |     |  |
|            |                  |                       |       | 0 0            |              |             | 0                                  |                                    |                                                                |                                       | priority level |        |           |     |     |     |     |     |     |     |     |     |     |   |  |    |  |  |  |   |  |  |     |  |
|            |                  |                       |       | 0 1            |              |             | 1                                  | Sets interrupt priority level to 3 |                                                                |                                       |                |        |           |     |     |     |     |     |     |     |     |     |     |   |  |    |  |  |  |   |  |  |     |  |
|            |                  |                       |       | 1 0            |              | 0           | Sets interrupt priority level to 4 |                                    |                                                                |                                       |                |        |           |     |     |     |     |     |     |     |     |     |     |   |  |    |  |  |  |   |  |  |     |  |
|            |                  |                       |       | 1              | 0            |             | 1                                  | Set                                | ts inte                                                        | rrupt p                               | oriority level | to 5   |           |     |     |     |     |     |     |     |     |     |     |   |  |    |  |  |  |   |  |  |     |  |
|            |                  |                       |       |                | 1            |             | 0                                  |                                    |                                                                |                                       | oriority level |        |           |     |     |     |     |     |     |     |     |     |     |   |  |    |  |  |  |   |  |  |     |  |
|            | 1 1 1            |                       |       | 1              |              |             |                                    |                                    |                                                                |                                       |                |        |           |     |     |     |     |     |     |     |     |     |     |   |  |    |  |  |  |   |  |  |     |  |

| Symbol    | Name             | Address | 7        | 6       |      | 5                                  |     | 4                           |                                                                       | 3                                  | 2         | 1       | 0      |       |      |   |   |  |   |     |  |  |  |   |  |     |  |
|-----------|------------------|---------|----------|---------|------|------------------------------------|-----|-----------------------------|-----------------------------------------------------------------------|------------------------------------|-----------|---------|--------|-------|------|---|---|--|---|-----|--|--|--|---|--|-----|--|
|           | INTRX1           |         |          |         | INTI | ГХ1                                |     |                             |                                                                       |                                    | INT       | RX1     |        |       |      |   |   |  |   |     |  |  |  |   |  |     |  |
| INTES1    | and              | 99H     | ITXT10   | C ITX1  | M2   | ITX1N                              | 11  | ITX1N                       | M0                                                                    | IRX1C                              | IRX1M2    | IRX1M1  | IRX1M0 |       |      |   |   |  |   |     |  |  |  |   |  |     |  |
| IIVILOI   | INTTX1           | 3311    | R        |         |      | R/W                                |     |                             |                                                                       | R                                  |           | R/W     |        |       |      |   |   |  |   |     |  |  |  |   |  |     |  |
|           | enable           |         | 0        | 0       | 0 0  |                                    |     | 0                           |                                                                       | 0                                  | 0         | 0       | 0      |       |      |   |   |  |   |     |  |  |  |   |  |     |  |
|           | INTSBI           |         |          |         | INTL | .CD                                |     |                             |                                                                       |                                    | INT       | SBI     |        |       |      |   |   |  |   |     |  |  |  |   |  |     |  |
| INTES2LCD | and              | 9AH     | ILCD10   | C ILCDI | M2   | ILCDM                              | 11  | ILCDI                       | M0                                                                    | ISBIC                              | ISBIM2    | ISBIM1  | ISBIM0 |       |      |   |   |  |   |     |  |  |  |   |  |     |  |
|           | INTLCD           | 07      | R        |         | 1    | R/W                                |     |                             |                                                                       | R                                  |           | R/W     |        |       |      |   |   |  |   |     |  |  |  |   |  |     |  |
|           | enable           |         | 0        | 0       |      | 0                                  |     | 0                           |                                                                       | 0                                  | 0         | 0       | 0      |       |      |   |   |  |   |     |  |  |  |   |  |     |  |
|           | INTTC0           |         |          | +       | INTT |                                    |     |                             |                                                                       |                                    |           | TC0     |        |       |      |   |   |  |   |     |  |  |  |   |  |     |  |
| INTETC01  | and              | 9BH     | ITC1C    | ITC1I   | M2   | ITC1N                              |     | ITC1I                       | M0                                                                    | ITC0C                              | ITC0M2    | ITC0M1  | ITC0M0 |       |      |   |   |  |   |     |  |  |  |   |  |     |  |
|           | INTTC1           |         | R        |         |      | R/W                                |     |                             |                                                                       | R                                  |           | R/W     |        |       |      |   |   |  |   |     |  |  |  |   |  |     |  |
|           | enable           |         | 0        | 0       |      | 0                                  |     | 0                           |                                                                       | 0                                  | 0         | 0       | 0      |       |      |   |   |  |   |     |  |  |  |   |  |     |  |
|           | INTTC2           |         |          | +       | INTT |                                    |     |                             |                                                                       |                                    | <b></b>   | TC2     |        |       |      |   |   |  |   |     |  |  |  |   |  |     |  |
| INTETC23  | and              | 9CH     | ITC3C    | ITC3I   | M2   | ITC3N                              |     | ITC3I                       | M0                                                                    | ITC2C                              | ITC2M2    | ITC2M1  | ITC2M0 |       |      |   |   |  |   |     |  |  |  |   |  |     |  |
|           | INTTC3<br>enable |         | R        |         |      | R/W                                |     |                             |                                                                       | R                                  |           | R/W     |        |       |      |   |   |  |   |     |  |  |  |   |  |     |  |
|           | enable           |         | 0        | 0       |      | 0                                  |     | 0                           |                                                                       | 0                                  | 0         | 0       | 0      |       |      |   |   |  |   |     |  |  |  |   |  |     |  |
|           | INTP0            |         |          | IN      |      |                                    |     |                             |                                                                       |                                    | <b></b>   | ΓP0     |        |       |      |   |   |  |   |     |  |  |  |   |  |     |  |
| INTEP01   | and              | 9DH     | IP1C     | IP1M    | 12   | IP1M                               |     | IP1N                        | 10                                                                    | IP0C                               | IP0M2     | IP0M1   | IP0M0  |       |      |   |   |  |   |     |  |  |  |   |  |     |  |
|           | INTP1            |         | R        |         | 1    | R/W                                |     |                             |                                                                       | R                                  | _         | R/W     |        |       |      |   |   |  |   |     |  |  |  |   |  |     |  |
|           | enable           |         | 0        | 0       |      | 0                                  |     | 0                           |                                                                       | 0                                  | 0         | 0       | 0      |       |      |   |   |  |   |     |  |  |  |   |  |     |  |
|           | INTRX2           |         |          |         | INTI |                                    |     |                             |                                                                       |                                    |           | RX2     | .=     |       |      |   |   |  |   |     |  |  |  |   |  |     |  |
| INTES3    | and              | A0H     | ITX2C    | ITX2    | M2   | 1                                  |     | ITX2                        | M0                                                                    | IRX2C                              | IRX2M2    | IRX2M1  | IRX2M0 |       |      |   |   |  |   |     |  |  |  |   |  |     |  |
|           | INTTX2<br>enable | AUH     | AUH      | A011    | AOIT | AUH                                | AUH | A0H -                       | A0H -                                                                 | A0H                                | AUH       | AUH     | AUH -  | AUH - | AOIT | R | R |  | 1 | R/W |  |  |  | R |  | R/W |  |
|           | enable           |         | 0        | 0       |      | 0                                  |     | 0                           |                                                                       | 0                                  | 0         | 0 0     |        |       |      |   |   |  |   |     |  |  |  |   |  |     |  |
|           | INTTB00          |         |          |         | INTT |                                    |     |                             |                                                                       |                                    | 1         | TB00    |        |       |      |   |   |  |   |     |  |  |  |   |  |     |  |
| INTETB0   | and              | A1H     | ITB1C    | ITB1    | M2   | ITB1N                              |     | ITB1N                       | M0                                                                    | ITB0C                              | ITB0M2    | ITB0M1  | ITB0M0 |       |      |   |   |  |   |     |  |  |  |   |  |     |  |
|           | INTTB01 enable   |         | R        |         | ı    | R/W                                |     |                             |                                                                       | R                                  |           | R/W     |        |       |      |   |   |  |   |     |  |  |  |   |  |     |  |
|           | CHADIC           |         | 0        | 0       |      | 0                                  |     | 0                           |                                                                       | 0                                  | 0         | 0       | 0      |       |      |   |   |  |   |     |  |  |  |   |  |     |  |
|           |                  |         |          |         |      |                                    |     |                             |                                                                       | ]                                  |           |         |        |       |      |   |   |  |   |     |  |  |  |   |  |     |  |
| Interr    | upt request      | flag ←  | <u> </u> |         |      |                                    |     |                             |                                                                       |                                    |           |         |        |       |      |   |   |  |   |     |  |  |  |   |  |     |  |
|           |                  |         |          |         |      |                                    |     |                             |                                                                       |                                    |           |         |        |       |      |   |   |  |   |     |  |  |  |   |  |     |  |
|           |                  |         | Γ        | lN40    | 1    |                                    | 1   |                             |                                                                       | Г.                                 |           | -:+ - \ |        |       |      |   |   |  |   |     |  |  |  |   |  |     |  |
|           |                  |         |          | lxxM2   | IX   | xM1                                | IX  | xM0                         |                                                                       |                                    | nction (W |         |        |       |      |   |   |  |   |     |  |  |  |   |  |     |  |
|           |                  |         |          | 0       |      | 0                                  |     | 0                           |                                                                       | sables interr                      |           |         |        |       |      |   |   |  |   |     |  |  |  |   |  |     |  |
|           |                  |         |          | 0       |      | 0                                  |     | 1<br>0                      |                                                                       | ets interrupt p                    |           |         |        |       |      |   |   |  |   |     |  |  |  |   |  |     |  |
|           |                  |         | 0        |         |      | 1                                  |     | 1                           |                                                                       | Sets interrupt priority level to 2 |           |         |        |       |      |   |   |  |   |     |  |  |  |   |  |     |  |
|           |                  |         | 0        |         |      | 0                                  |     |                             | Sets interrupt priority level to 3 Sets interrupt priority level to 4 |                                    |           |         |        |       |      |   |   |  |   |     |  |  |  |   |  |     |  |
|           |                  |         |          | 1       |      | 0                                  |     | 1                           |                                                                       | ets interrupt p                    | -         |         |        |       |      |   |   |  |   |     |  |  |  |   |  |     |  |
|           |                  |         | 1 1 0    |         |      | Sets interrupt priority level to 6 |     |                             |                                                                       |                                    |           |         |        |       |      |   |   |  |   |     |  |  |  |   |  |     |  |
|           |                  |         | 1 1      |         |      |                                    | 1   | Disables interrupt requests |                                                                       |                                    |           |         |        |       |      |   |   |  |   |     |  |  |  |   |  |     |  |

| (2) External interrupt contr | rol |
|------------------------------|-----|
|------------------------------|-----|

| Symbol | Name                 | Address | 7          | 6      | 5          | 4          | 3          | 2          | 1               | 0                             |             |
|--------|----------------------|---------|------------|--------|------------|------------|------------|------------|-----------------|-------------------------------|-------------|
|        |                      | -       | Ī          | I3EDGE | I2EDGE     | I1EDGE     | I0EDGE     | IOLE       | NMIREE          |                               |             |
|        |                      |         |            |        |            | ٧          | _          | _          |                 |                               |             |
|        |                      | node    | 0          | 0      | 0          | 0          | 0          | 0          | 0               | 0                             |             |
|        | Interrupt input mode |         |            | Always | Always     | INT3EDGE   | INT2EDGE   | INT1EDGE   | INT0EDGE        | 0: INT0                       | 1: Operates |
| _      | control              |         | write "0". |        | 0: Rising  | 0: Rising  | 0: Rising  | 0: Rising  | edge            | even on<br>rising/<br>falling |             |
|        |                      |         |            |        | 1: Falling | 1: Falling | 1: Falling | 1: Falling | mode<br>1: INT0 |                               |             |
|        |                      |         |            |        |            |            |            |            | level           | edge of                       |             |
|        |                      |         |            |        |            |            |            |            | mode            | NMI                           |             |

| INT0 leve | el enable ←     |
|-----------|-----------------|
| 0         | edge detect INT |
| 1         | H level INT     |
| NMI risir | ng edge enable  |
|           |                 |

| 0 | INT request generation at falling edge        |
|---|-----------------------------------------------|
| 1 | INT request generation at rising/falling edge |

### (3) Interrupt request flag clear register

The interrupt request flag is cleared by writing the appropriate micro DMA start vector, as given in Table 3.4.1 to the register INTCLR.

For example, to clear the interrupt flag INTO, perform the following register operation after execution of the DI instruction.

INTCLR  $\leftarrow$  0AH: Clears interrupt request flag INT0.

| Symbol | Name                          | Address                  | 7 | 6 | 5                | 4     | 3     | 2     | 1     | 0     |
|--------|-------------------------------|--------------------------|---|---|------------------|-------|-------|-------|-------|-------|
|        |                               |                          |   |   | CLRV5            | CLRV4 | CLRV3 | CLRV2 | CLRV1 | CLRV0 |
|        | Interrupt<br>clear<br>control | 88H<br>(Prohibit<br>RMW) |   |   | W                |       |       |       |       |       |
| INTCLR |                               |                          |   |   | 0                | 0     | 0     | 0     | 0     | 0     |
|        |                               |                          |   |   | Interrupt vector |       |       |       |       |       |

## (4) Micro DMA start vector registers

This register assigns micro DMA processing to an interrupt source. The interrupt source with a micro DMA start vector that matches the vector set in this register is assigned as the micro DMA start source. When the micro DMA transfer counter value reaches zero, the micro DMA transfer end interrupt corresponding to the channel is sent to the interrupt controller, the micro DMA start vector register is cleared, and the micro DMA start source for the channel is cleared. Therefore, to continue micro DMA processing, set the micro DMA start vector register again during the processing of the micro DMA transfer end interrupt.

If the same vector is set in the micro DMA start vector registers of more than one channel; the channel with the lowest number has a higher priority.

Accordingly, if the same vector is set in the micro DMA start vector registers of two channels, the interrupt generated in the channel with the lower number is executed until micro DMA transfer is complete. If the micro DMA start vector for this channel is not set again, the next micro DMA is started for the channel with the higher number. (Micro DMA chaining.)

| Symbol      | Name                  | Address | 7 | 6 | 5                 | 4      | 3       | 2          | 1      | 0      |
|-------------|-----------------------|---------|---|---|-------------------|--------|---------|------------|--------|--------|
|             |                       |         |   |   | DMA0 start vector |        |         |            |        |        |
| DMA0V start | DMA0                  | 9011    |   |   | DMA0V5            | DMA0V4 | DMA0V3  | DMA0V2     | DMA0V1 | DMA0V0 |
|             | vector                | 80H     |   |   |                   |        | R/      | W          |        |        |
|             |                       |         |   |   | 0                 | 0      | 0       | 0          | 0      | 0      |
|             |                       |         |   |   |                   |        | DMA1 st | art vector |        |        |
| DMA1        |                       | 81H     |   |   | DMA1V5            | DMA1V4 | DMA1V3  | DMA1V2     | DMA1V1 | DMA1V0 |
| DMA1V       | start<br>vector       |         |   |   | R/W               |        |         |            |        |        |
|             |                       |         |   |   | 0                 | 0      | 0       | 0          | 0      | 0      |
|             |                       |         |   |   |                   |        | DMA2 st | art vector | _      |        |
| DMA2V       | DMA2                  | 82H     |   |   | DMA2V5            | DMA2V4 | DMA2V3  | DMA2V2     | DMA2V1 | DMA2V0 |
| DIVIAZV     | DMA2V start<br>vector |         |   |   |                   |        | R/      | W W        |        |        |
|             |                       |         |   |   | 0                 | 0      | 0       | 0          | 0      | 0      |
|             |                       |         |   |   |                   |        | DMA3 st | art vector |        |        |
| DMAAOV/     | DMA3                  | 83H     |   |   | DMA3V5            | DMA3V4 | DMA3V3  | DMA3V2     | DMA3V1 | DMA3V0 |
| DMA3V       | start<br>vector       |         |   |   |                   |        | R/      | W          |        |        |
|             | 100.01                |         |   |   | 0                 | 0      | 0       | 0          | 0      | 0      |

# (5) Micro DMA burst specification

Specifying the micro DMA burst continues the micro DMA transfer until the transfer counter register reaches zero after micro DMA start. Setting a bit which corresponds to the micro DMA channel of the DMAB registers mentioned below to 1 specifies a burst.

| Symbol | Name                | Address   | 7 | 6 | 5 | 4 | 3                    | 2           | 1           | 0     |
|--------|---------------------|-----------|---|---|---|---|----------------------|-------------|-------------|-------|
|        | DMA                 |           |   |   |   |   | DMAR3                | DMAR2       | DMAR1       | DMAR0 |
| DMAR   | software            | (Prohibit |   |   |   |   | R/W                  | R/W         | R/W         | R/W   |
| DIVIAR | request<br>register |           |   |   |   |   | 0                    | 0           | 0           | 0     |
|        |                     |           |   |   |   |   |                      | 1: DMA soft | ware reques | t     |
|        |                     | urst 8AH  |   |   |   |   | DMAB3                | DMAB2       | DMAB1       | DMAB0 |
| DMAR   | DMA                 |           |   |   |   |   |                      | R/          | W           |       |
| DMAB   | register            |           |   |   |   |   | 0                    | 0           | 0           | 0     |
|        |                     |           |   |   |   |   | 1: DMA burst request |             |             |       |

### (6) Notes

The instruction execution unit and the bus interface unit of this CPU operate independently. Therefore, immediately before an interrupt is generated, if the CPU fetches an instruction that clears the corresponding interrupt request flag, the CPU may execute the instruction that clears the interrupt request flag between accepting and reading the interrupt vector. In this case, the CPU reads the default vector 0008H and reads the interrupt vector address FFFF08H.

To avoid the above problem, place instructions that clear interrupt request flags after a DI instruction. And in the case of setting an interrupt enable again by EI instruction after the execution of clearing instruction, execute EI instruction after clearing and more than 1 instructions (ex. "NOP"  $\times$  1 time). If placed EI instruction without waiting NOP instruction after execution of clearing instruction, interrupt will be enable before request flag is cleared.

In the case of changing the value of the interrupt mask register <IFF2:0> by execution of POP SR instruction, disable an interrupt by DI instruction before execution of POP SR instruction.

In addition, take care as the following 2 circuits are exceptional and demand special attention.

| ;INT0 level mode | In level mode INT0 is not an edge-triggered interrupt. Hence, in level mode the interrupt request flip-flop for INT0 does not function. The peripheral interrupt request passes through the S input of the flip-flop and becomes the Q output. If the interrupt input mode is changed from edge mode to level mode, the interrupt request flag is cleared automatically.                                                                                                                                                                                                                                                                                                                             |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  | If the CPU enters the interrupt response sequence as a result of INTO going from 0 to 1, INTO must then be held at 1 until the interrupt response sequence has been completed. If INTO is set to level mode so as to release a halt state, INTO must be held at 1 from the time INTO changes from 0 to 1 until the halt state is released. (Hence, it is necessary to ensure that input noise is not interpreted as a 0, causing INTO to revert to 0 before the halt state has been released.)  When the mode changes from level mode to edge mode, interrupt request flags which were set in level mode will not be cleared.  Interrupt request flags must be cleared using the following sequence. |
|                  | LD (IIMC), 00H ; Switches interrupt input mode from level mode to edge mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                  | LD (INTCLR), 0AH; Clears interrupt request flag.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                  | NOP ; Wait EI instruction                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                  | EI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| INTRX            | The interrupt request flip-flop can only be cleared by a reset or by reading the serial channel receive buffer. It cannot be cleared by writing INTCLR register.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

Note: The following instructions or pin input state changes are equivalent to instructions that clear the interrupt request flag.

INT0: Instructions which switch to level mode after an interrupt request has been generated in edge mode.

The pin input changes from high to low after an interrupt request has been generated in level mode. (H  $\rightarrow$  L)

INTRX: Instructions which read the receive buffer.

# 3.5 Port Functions

The TMP91C820A features 126-bit settings which relate to the various I/O ports.

As well as general-purpose I/O port functionality, the port pins also have I/O functions which relate to the built-in CPU and internal I/Os. Table 3.5.1 and Table 3.5.2 list the functions of each port pin. Table 3.5.3, Table 3.5.4 and Table 3.5.5 list I/O registers and their specifications.

Table 3.5.1 Port Functions (1/2)

(R: PU = with programmable pull-up resistor) (U = with pull-up resistor)

| Port Name | Pin Name   | Number of Pins | Direction | R  | Direction<br>Setting Unit | Pin Name for Built-in<br>Function    |
|-----------|------------|----------------|-----------|----|---------------------------|--------------------------------------|
| Port 0    | P00 to P07 | 8              | I/O       | =  | Bit                       | D0 to D7                             |
| Port 1    | P10 to P17 | 8              | I/O       | _  | Bit                       | D8 to D15                            |
| Port 2    | P20 to P27 | 8              | I/O       | -  | Bit                       | A16 to A23                           |
| Port 3    | P30 to P37 | 8              | I/O       | -  | Bit                       | A8 to A15                            |
| Port 4    | P40 to P47 | 8              | I/O       | -  | Bit                       | A0 to A7                             |
| Port Z    | PZ0        | 1              | Output    | =  | Bit                       | RD                                   |
|           | PZ1        | 1              | Output    | -  | Bit                       | WR                                   |
|           | PZ2        | 1              | I/O       | PU | Bit                       | HWR                                  |
|           | PZ3        | 1              | I/O       | PU | Bit                       | $R/\overline{W}$ , $\overline{SRWE}$ |
| Port 5    | P56        | 1              | I/O       | PU | Bit                       | WAIT                                 |
| Port 6    | P60        | 1              | Output    | -  | (Fixed)                   | CS0                                  |
|           | P61        | 1              | Output    | -  | (Fixed)                   | CS1, SDCS                            |
|           | P62        | 1              | Output    | -  | (Fixed)                   | CS2, CS2A                            |
|           | P63        | 1              | Output    | -  | (Fixed)                   | CS3                                  |
|           | P64        | 1              | Output    | -  | (Fixed)                   | EA24, CS2B                           |
|           | P65        | 1              | Output    | -  | (Fixed)                   | EA25, CS2C                           |
|           | P66        | 1              | Output    | -  | (Fixed)                   | CS2C, SRLB                           |
|           | P67        | 1              | Output    | -  | (Fixed)                   | CS2E, SRUB                           |
| Port 7    | P70        | 1              | I/O       | _  | Bit                       | SCK, OPTRX0                          |
|           | P71        | 1              | I/O       | -  | Bit                       | SO, SDA, OPTTX0                      |
|           | P72        | 1              | I/O       | -  | Bit                       | SI/SCL                               |
|           | P73        | 1              | I/O       | -  | Bit                       | CS2F                                 |
|           | P74        | 1              | I/O       | _  | Bit                       | <del>CS2G</del>                      |
|           | P75        | 1              | I/O       | _  | Bit                       | CSEXA                                |
|           | P76        | 1              | I/O       | -  | Bit                       | MSK                                  |
|           | P77        | 1              | I/O       | -  | Bit                       | VEECLK                               |
| Port 8    | P80 to P87 | 8              | Input     | _  | (Fixed)                   | AN0 to AN7, ADTRG (P83)              |
| Port 9    | P90 to P97 | 8              | Input     | U  | (Fixed)                   | KI0 to KI7                           |
| Port A    | PA0 to PA7 | 8              | Output    | =  | (Fixed)                   | KO0 to KO7                           |
| Port B    | PB0        | 1              | I/O       | -  | Bit                       | TA0IN, TXD2                          |
|           | PB1        | 1              | I/O       | -  | Bit                       | TA1OUT, RXD2                         |
|           | PB3        | 1              | I/O       | -  | Bit                       | INT0                                 |
|           | PB4        | 1              | I/O       | -  | Bit                       | INT1                                 |
|           | PB5        | 1              | I/O       | -  | Bit                       | INT2, TA3OUT                         |
|           | PB6        | 1              | I/O       | -  | Bit                       | INT3, TB0OUT0                        |
| Port C    | PC0        | 1              | I/O       |    | Bit                       | TXD0                                 |
|           | PC1        | 1              | I/O       | -  | Bit                       | RXD0                                 |
|           | PC2        | 1              | I/O       | -  | Bit                       | SCLK0, CTS0                          |
|           | PC3        | 1              | I/O       | -  | Bit                       | TXD1                                 |
|           | PC4        | 1              | I/O       | -  | Bit                       | RXD1                                 |
|           | PC5        | 1              | I/O       | -  | Bit                       | SCLK1, CTS1                          |

Table 3.5.2 Port Functions (2/2)

(R: PU = with programmable pull-up resistor) (U = with pull-up resistor)

| Port Name | Pin Name   | Number of Pins | Direction | R | Direction<br>Setting Unit | Pin Name for Built-in<br>Function |
|-----------|------------|----------------|-----------|---|---------------------------|-----------------------------------|
| Port D    | PD0        | 1              | Output    | - | (Fixed)                   | D1BSCP                            |
|           | PD1        | 1              | Output    | - | (Fixed)                   | D2BLP                             |
|           | PD2        | 1              | Output    | - | (Fixed)                   | D3BFR                             |
|           | PD3        | 1              | Output    | - | (Fixed)                   | DLEBCD                            |
|           | PD4        | 1              | Output    | - | (Fixed)                   | DOFFB                             |
|           | PD6        | 1              | Output    | - | (Fixed)                   | ALARM, MLDALM                     |
|           | PD7        | 1              | Output    | - | (Fixed)                   | MLDALM                            |
| Port E    | PD0 to PD7 | 8              | I/O       | _ | Bit                       | LD0 to LD7                        |
| Port F    | PF0        | 1              | Output    | - | (Fixed)                   | SDRAS                             |
|           | PF1        | 1              | Output    | - | (Fixed)                   | SDCAS                             |
|           | PF2        | 1              | Output    | - | (Fixed)                   | SDWE                              |
|           | PF3        | 1              | Output    | - | (Fixed)                   | SDLDQM                            |
|           | PF4        | 1              | Output    | - | (Fixed)                   | SDUDQM                            |
|           | PF5        | 1              | Output    | - | (Fixed)                   | SDCKE                             |
|           | PF6        | 1              | Output    | - | (Fixed)                   | SDCLK                             |
|           | PF7        | 1              | Output    | ı | (Fixed)                   |                                   |

Table 3.5.3 I/O Registers and Specifications (1/3)

| Port   | Pin Name   | Specification           |                 | I/O Re       | gister                                                                                                               |       |
|--------|------------|-------------------------|-----------------|--------------|----------------------------------------------------------------------------------------------------------------------|-------|
| Port   | Pin Name   | Specification           | Pn              | PnCR         | PnFC                                                                                                                 | PnFC2 |
| Port 0 | P00 to P07 | Input port              | X               | 0            |                                                                                                                      |       |
|        |            | Output port             | Х               | 1            | None                                                                                                                 | None  |
|        |            | D0 to D7 bus            | Х               | Х            |                                                                                                                      |       |
| Port 1 | P10 to P17 | Input port              | X               | 0            | 0                                                                                                                    |       |
|        |            | Output port             | Х               | 1            | 0                                                                                                                    | None  |
|        |            | D8 to D15 bus           | X               | 0            | 1                                                                                                                    |       |
| Port 2 | P20 to P27 | Input port              | Х               | 0            | Х                                                                                                                    |       |
|        |            | Output port             | X               | 1            | 0                                                                                                                    | None  |
|        |            | A16 to A23 output       | Х               | 1            | 1                                                                                                                    |       |
| Port 3 | P30 to P47 | Input port              | Х               | 0            | Х                                                                                                                    |       |
|        |            | Output port             | Х               | 1            | 0                                                                                                                    | None  |
|        |            | A8 to A15 output        | Х               | 1            | 1                                                                                                                    |       |
| Port 4 | P30 to P47 | Input port              | Х               | 0            | Х                                                                                                                    |       |
|        |            | Output port             | Х               | 1            | 0                                                                                                                    | None  |
|        |            | A0 to A7 output         | Х               | 1            | 1                                                                                                                    |       |
| Port Z | PZ0        | Output port             | X               |              | 0                                                                                                                    |       |
|        |            | RD output               | Х               | None         | 1                                                                                                                    |       |
|        | PZ1        | Output port             | X               | None         | 0                                                                                                                    |       |
|        |            | WR output               | X               |              | 1                                                                                                                    |       |
|        | PZ2, PZ3   | Input port (without PU) | 0               | 0            | 0                                                                                                                    |       |
|        |            | Input port (with PU)    | 1               | 0            | 0                                                                                                                    |       |
|        |            | Output port             | Output port X 1 |              | 0                                                                                                                    |       |
|        | PZ2        | HWR output              | Х               | 1            | 1                                                                                                                    | None  |
|        | PZ3        | R/W output              | X               | 0            | 1                                                                                                                    |       |
|        |            | SRWE output             | X               | 1            | 1                                                                                                                    |       |
| Port 5 | P56        | Input port (without PU) | 0               | 0            |                                                                                                                      |       |
|        |            | Input port (with PU)    | 1               | 0            |                                                                                                                      |       |
|        |            | Output port             | X 1 N           |              | None                                                                                                                 |       |
|        |            | WAIT input (without PU) | 0               | 0            |                                                                                                                      |       |
|        |            | WAIT input (with PU)    | 1               | 0            | 0<br>1<br>X<br>0<br>1<br>X<br>0<br>1<br>0<br>1<br>0<br>0<br>1<br>0<br>0<br>1<br>1<br>1<br>0<br>0<br>1<br>1<br>1<br>1 |       |
| Port 6 | P60 to P67 | Output port             | X               |              | 0<br>1<br>X<br>0<br>1<br>X<br>0<br>1<br>0<br>1<br>0<br>0<br>1<br>0<br>0<br>1<br>1<br>0<br>0<br>1<br>1<br>1<br>1      | 0     |
|        | P60        | CS0 output              | X               |              | 1                                                                                                                    | 0     |
|        | P61        | CS1 output              | X               | _            |                                                                                                                      | 0     |
|        |            | SDCS output             | X               |              | X                                                                                                                    | 1     |
|        | P62        | CS2 output              | Х               |              |                                                                                                                      | 0     |
|        |            | CS2A output             | Х               |              | X                                                                                                                    | 1     |
|        | P63        | CS3 output              | Х               |              | 1                                                                                                                    | 0     |
|        | P64        | EA24 output             | Х               | None         | 1                                                                                                                    | 0     |
|        |            | CS2B output             | Х               |              | X                                                                                                                    | 1     |
|        | P65        | EA25 output             |                 |              | 1                                                                                                                    | 0     |
|        |            | CS2C output             | Х               |              | Х                                                                                                                    | 1     |
|        | P66        | SRLB output             | X               |              | 1                                                                                                                    | 0     |
|        |            | CS2D output             | Х               |              | Х                                                                                                                    | 1     |
|        | P67        | SRUB output             | Х               | <del>-</del> |                                                                                                                      | 0     |
|        | <u> </u>   | CS2E output             | X               | Х            | 1                                                                                                                    |       |

X: Don't care

Table 3.5.4 I/O Registers and Specifications (2/3)

| Dowt   | Din Nome   | Charification                  |                | I/O Register |                                                  |        |  |  |  |
|--------|------------|--------------------------------|----------------|--------------|--------------------------------------------------|--------|--|--|--|
| Port   | Pin Name   | Specification                  | Pn             | PnCR         | PnFC                                             | PnFC2  |  |  |  |
| Port 7 | P70 to P77 | Input port                     | Х              | 0            | 0                                                | 0      |  |  |  |
|        |            | Output port                    | Х              | 1            | 0                                                | 0      |  |  |  |
|        | P70        | SCK input                      | Х              | 0            | 0                                                | 0      |  |  |  |
|        |            | SCK output                     | Х              | 1            | 1                                                | 0      |  |  |  |
|        |            | OPTRX0 input (Note 1)          | 1              | 0            | Х                                                | 1      |  |  |  |
|        | P71        | SDA input                      | Х              | 0            | 0                                                | 0      |  |  |  |
|        |            | SDA output (Note 2)            | Х              | 1            | 1                                                | 0      |  |  |  |
|        |            | SO output                      | Х              | 1            | 1                                                | 0      |  |  |  |
|        |            | OPTTX0 output (Note 1)         | 1              | 1            | Х                                                | 1      |  |  |  |
|        | P72        | SI input                       | Х              | 0            | 0                                                |        |  |  |  |
|        |            | SCL input                      | Х              | 0            | 0                                                | None   |  |  |  |
|        |            | SCL output (Note 2)            | Х              | 1            | 1                                                |        |  |  |  |
|        | P73        | CS2F output                    | Х              | 1            | Х                                                | 1      |  |  |  |
|        | P74        | CS2G output                    | X              | 1            | Х                                                | 1      |  |  |  |
|        | P75        | CSEXA output                   | X              | 1            | Х                                                | 1      |  |  |  |
|        | P76        | MSK input (Note 3)             | X              | 0            | 0                                                | 0      |  |  |  |
|        | P77        | VEECLK output                  | Х              | 1            | 1                                                | 0      |  |  |  |
| Port 8 | P80 to P87 | Input port                     | X              |              |                                                  |        |  |  |  |
|        |            | AN0 to AN7 input (Note 4)      | X              | Noi          | ne                                               |        |  |  |  |
|        | P83        | ADTRG input (Note 5)           | Х              |              |                                                  | - None |  |  |  |
| Port 9 | P90 to P97 | Input port                     | Х              | None 0       |                                                  |        |  |  |  |
|        |            | KI0 to KI7 input               | Х              | None         | 1                                                | NONE   |  |  |  |
| Port A | PA0 to PA7 | Output port                    | Х              |              | 0                                                |        |  |  |  |
|        |            | KO0 to KO7 output (CMOS)       | Х              | None         | 0                                                |        |  |  |  |
|        |            | KO0 to KO7 output (Open drain) | Х              |              | 1                                                |        |  |  |  |
| Port B | PB0 to PB6 | Input port                     | Х              | 0            | 0                                                |        |  |  |  |
|        |            | Output port                    | X              | 1            | 0                                                |        |  |  |  |
|        | PB0        | TA0IN input                    | Х              | 0            | 0                                                |        |  |  |  |
|        |            | TXD2 output (Note 1)           | Х              | 1            | 1                                                |        |  |  |  |
|        | PB1        | TA1OUT output                  | Х              | 1            | 1                                                |        |  |  |  |
|        |            | RXD2 input (Note 1)            | Х              | 0            | 0                                                | 1      |  |  |  |
|        | PB3        | INTO input                     | Х              | 0            | 1                                                | None   |  |  |  |
|        | PB4        | INT1 input                     | Х              | 0            | 1                                                | 1      |  |  |  |
|        | PB5        | INT2 input                     | 0              | 0            | 1                                                | 1      |  |  |  |
|        |            | TA3OUT                         | 1              | 1            | 1                                                | 1      |  |  |  |
|        |            |                                | <del>-  </del> | <del></del>  | <del>-                                    </del> | 4      |  |  |  |
|        | PB6        | INT3 input                     | 0              | 0            | 1                                                |        |  |  |  |

X: Don't care

Table 3.5.5 I/O Registers and Specifications (3/3)

| Dort   | Din Nama   | Specification     |             |    | I/O Register |      |        |  |
|--------|------------|-------------------|-------------|----|--------------|------|--------|--|
| Port   | Pin Name   |                   |             | Pn | PnCR         | PnFC | PnFC2  |  |
| Port C | PC0 to PC5 | Input port        |             | Х  | 0            | 0    |        |  |
|        |            | Output port       |             | Х  | 1            | 0    |        |  |
|        | PC0        | TXD0 output       | (Note 1)    | 1  | 1            | 1    |        |  |
|        | PC1        | RXD0 input        | (Note 1, 6) | 1  | 0            | None |        |  |
|        | PC2        | SCLK0 input       | (Note 1)    | 1  | 0            | 0    |        |  |
|        |            | SCLK0 output      | (Note 1)    | 1  | 1            | 1    |        |  |
|        |            | CTS0 input        | (Note 1)    | 1  | 0            | 0    |        |  |
|        | PC3        | TXD1 output       | (Note 1)    | 1  | 1            | 1    |        |  |
|        | PC4        | RXD1 input        | (Note 1)    | 1  | 0            | None |        |  |
|        | PC5        | SCLK1 input       | (Note 1)    | 1  | 0            | 0    |        |  |
|        |            | SCLK1 output      | (Note 1)    | 1  | 1            | 1    |        |  |
|        |            | CTS1 input        | (Note 1)    | 1  | 0            | 0    |        |  |
| Port D | PD0 to PD7 | Output port       |             | Х  |              | 0    |        |  |
|        | PD0        | D1BSCP output     |             | Х  | 1            | 1    | - None |  |
|        | PD1        | D2BLP output      |             | Х  |              | 1    |        |  |
|        | PD2        | D3BFR output      |             | Х  |              | 1    |        |  |
|        | PD3        | DLEBCD output     |             | Х  | None         | 1    | None   |  |
|        | PD4        | DOFFB output      |             | Х  |              | 1    |        |  |
|        | PD6        | ALARM output      |             | 1  | 1 1          | 1    |        |  |
|        |            | MLDALM output     |             | 0  |              | 1    |        |  |
|        | PD7        | MLDALM output     |             | Х  |              | 1    |        |  |
| Port E | PE0 to PE7 | Input port        |             | Х  | 0            | 0    |        |  |
|        |            | Output port       |             | Х  | 1            | 0    |        |  |
|        |            | LD0 to LD7 output |             | Х  | 1            | 1    |        |  |
| Port F | PF0 to PF7 | Output port       |             | Х  |              | 0    |        |  |
|        | PF0        | SDRAS output      |             | Х  | 1 1 1 None   | ]    |        |  |
|        | PF1        | SDCAS output      |             | Х  |              | 1    |        |  |
|        | PF2        | SDWE output       |             | Х  |              | 1    |        |  |
|        | PF3        | SDLDQM output     |             | Х  | 1            |      |        |  |
|        | PF4        | SDUDQM output     |             | Х  | 1            |      |        |  |
|        | PF5        | SDCKE output      | Х           | 1  |              | ]    |        |  |
|        | PF6        | SDCLK output      |             | Х  | <u> </u>     | 1    |        |  |

X: Don't care

- Note 1: As for input ports of SIO1 to SIO3: (OPTTX0, OPTRX0, TXD0, RXD0, SCLK0,  $\overline{\text{CTS0}}$ , TXD1, RXD1, SCLK1,  $\overline{\text{CTS1}}$ , TXD2, RXD2), logical selection for output data or input data is determined by the output latch register Pn of each port.
- Note 2: When P71/P72 are used as SDA/SCL open-drain outputs, P70DE<ODEP72:71> is used to set the open-drain output mode.
- Note 3: In case using P76 for MSK port, set to P7FC<P76F>.
- Note 4: When P80 to P87 are used as AD converter input channels, ADMOD1<ADCH2:0> is used to select the channel.
- Note 5: When P83 is used as ADTRGE input, ADMOD1<ADTRGE> is used to enable external-trigger input.
- Note 6: In case using PC1 for RXD0 port, set "0" to P7FC2<P70F2>.

# 3.5.1 Port 0 (P00 to P07)

Port 0 is an 8-bit general-purpose I/O port. Each bit can be set individually for input or output using the control register P0CR. Resetting resets all bits of the output latch P0, the control register P0CR to 0 and sets port 0 to input mode. In addition to functioning as a general-purpose I/O port, port 0 can also function as an data bus (D0 to D7).

When external memory is accessed, the port automatically functions as the data bus (D0 to D7) and all bits of P0CR are cleared to 0.



Figure 3.5.1 Port 0

#### Port 0 Register 7 6 5 4 3 2 1 0 P0 P07 P06 P05 P04 P03 P02 P01 P00 Bit symbol (0000H)Read/Write R/W After reset Data from external port (Output latch register is cleared to 0.) Port 0 Control Register 7 6 5 4 3 2 1 0 Bit symbol P07C P06C P05C P04C P03C P<sub>02</sub>C P01C P00C P0CR (0002H)Read/Write W After reset 0 0 0 0 0 0 0

Note 1: Read-modify-write is prohibited for P0CR.

Function

Note 2: When functioning as a data bus (D0 to D7), P0CR is cleared to 0.

Figure 3.5.2 Register for Port 0

Port 0 input/output settings
0: Input 1:Output

# 3.5.2 Port 1 (P10 to P17)

Port 1 is an 8-bit general-purpose I/O port. Each bit can be set individually for input or output using the control register P1CR and the function register P1FC. Resetting resets all bits of the output latch P1, the control register P1CR and the function register P1FC to 0 and sets port 1 to input mode.

In addition to functioning as a general-purpose I/O port, port 1 can also function as an data bus (D8 to D15).

| AM1 | AM0 | P1xF | Function Setting after Reset is Released |  |
|-----|-----|------|------------------------------------------|--|
| 0   | 0   | 0    | Input port                               |  |
| 0   | 1   | 1    | Data bus (D8 to D15)                     |  |
| 1   | 0   | -    | Don't use this setting                   |  |
| 1   | 1   | 0    | Input port                               |  |



Figure 3.5.3 Port 1

Port 1 Register

6 0 5 4 3 2 1 P1 P17 Bit symbol P16 P15 P14 P13 P12 P11 P10 (0001H) Read/Write R/W After reset Data from external port (Output latch register is cleared to 0.) Port 1 Control Register 6 5 4 3 2 1 0 P1CR Bit symbol P17C P16C P15C P14C P13C P12C P11C P10C (0004H) Read/Write After reset 0 0 0 0 0 0 0 0 Function Port 1 function settings Port 1 Function Register 7 6 5 4 3 2 1 0 P1FC P14F Bit symbol P17F P16F P15F P13F P12F P11F P10F (0005H) Read/Write W After reset 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 (Note3) **Function** Port 1 function settings ➤ Port 1 function settings Note 1: Read-modify-write is prohibited for P1CR P1FC<P1xF> and P1FC. 0 1 Note 2: <P1xF> is bit x in register P1FC; <P1xC>, P1CR<P1xC> in register P1CR. Note 3: It is set to "Port" or "Data bus " by AM pins Data bus 0 Input port state. (D15 to D8) 1 Output port Don't set

Figure 3.5.4 Register for Port 1

# 3.5.3 Port 2 (P20 to P27)

Port 2 is an 8-bit general-purpose I/O port. Each bit can be set individually for input or output using the control register P2CR and the function register P2FC. In addition to functioning as a general-purpose I/O port, port 2 can also function as an address bus (A16 to A23).

Setting the AM1 and AM0 pins as shown below and resetting the device initialize port 2 to the following function pins.

| AM1 | AM0 | P2xC | P2xF | Function Setting after Reset is Released |
|-----|-----|------|------|------------------------------------------|
| 0   | 0   | 1    | 1    | Address bus (A16 to A23)                 |
| 0   | 1   | 1    | 1    | Address bus (A16 to A23)                 |
| 1   | 0   | -    | _    | Don't use this setting                   |
| 1   | 1   | 0    | 0    | Input port                               |



Figure 3.5.5 Port 2

#### Port 2 Register 6 5 3 2 0 P2 Bit symbol P27 P26 P25 P24 P23 P22 P21 P20 (0006H) Read/Write After reset Data from external port (Output latch register is cleared to 0.) Port 2 Control Register 2 6 5 4 3 1 0 P2CR Bit symbol P27C P26C P25C P24C P23C P22C P21C P20C (0008H)Read/Write After reset 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 (Note3) Function Port 2 function settings Port 2 Function Register P2FC 7 6 5 4 3 2 1 0 (0009H) P27F P26F P25F P24F P22F P21F P20F Bit symbol P23F Read/Write W After reset 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 (Note3) Port 2 function settings **Function** Note 1: Read-modify-write is prohibited for P2CR and P2FC. Port 2 function settings Note 2: <P2xF> is bit x in register P2FC; <P2xC>, P2FC<P2xF> in register P2CR. 0 Note 3: It is set to "Port" or "Address bus " by AM P2CR<P2xC> pins state.

Figure 3.5.6 Register for Port 2

0

1

Input port

Output port

Address bus

(A16 to A23)

# 3.5.4 Port 3 (P30 to P37)

Port 3 is an 8-bit general-purpose I/O port. Each bit can be set individually for input or output using the control register P3CR and the function register P3FC. In addition to functioning as a general-purpose I/O port, port 3 can also function as an address bus (A8 to A15).

Setting the AM1 and AM0 pins as shown below and resetting the device initialize port 3 to the following function pins.

| AM1 | AM0 | P3xC | P3xF | Function Setting after Reset is Released |
|-----|-----|------|------|------------------------------------------|
| 0   | 0   | 1    | 1    | Address bus (A8 to A15)                  |
| 0   | 0   | 1    | 1    | Address bus (A8 to A15)                  |
| 1   | 0   | -    | -    | Don't use this setting                   |
| 1   | 1   | 0    | 0    | Input port                               |



Figure 3.5.7 Port 3



Figure 3.5.8 Register for Port 3

# 3.5.5 Port 4 (P40 to P47)

Port 4 is an 8-bit general-purpose I/O port. Each bit can be set individually for input or output using the control register P4CR and the function register P4FC. In addition to functioning as a general-purpose I/O port, port 4 can also function as an address bus (A0 to A7).

Setting the AM1 and AM0 pins as shown below and resetting the device initialize port 4 to the following function pins.

| AM1 | AM0 | P4xC | P4xF | Function Setting after Reset is Released |
|-----|-----|------|------|------------------------------------------|
| 0   | 0   | 1    | 1    | Address bus (A0 to A7)                   |
| 0   | 1   | 1    | 1    | Address bus (A0 to A7)                   |
| 1   | 0   | -    | -    | Don't use this setting                   |
| 1   | 1   | 0    | 0    | Input port                               |



Figure 3.5.9 Port 4

Port 4 Register

#### 6 5 3 2 0 P4 Bit symbol P47 P46 P45 P44 P43 P42 P41 P40 (000CH) Read/Write After reset Data from external port (Output latch register is cleared to 0.) Port 4 Control Register 7 2 6 5 4 3 1 0 P4CR Bit symbol P47C P46C P45C P44C P43C P42C P41C P40C (000EH) Read/Write After reset 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 (Note3) Function Port 4 function settings Port 4 Function Register P4FC 7 6 5 4 3 2 1 0 (000FH) P47F P46F P45F P44F P43F P42F P41F P40F Bit symbol Read/Write W After reset 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 (Note3) Port 4 function settings **Function** Note 1: Read-modify-write is prohibited for P4CR Port 4 function settings and P4FC. Note 2: <P4xF> is bit x in register P4FC; <P4xC>, P4FC<P4xF> in register P4CR. 0 Note 3: It is set to "Port" or "Address bus" by AM P4CR<P4xC> pins state. 0 Input port Address bus 1 Output port

Figure 3.5.10 Register for Port 4

(A0 to A7)

TOSHIBA

# 3.5.6 Port Z (PZ0 to PZ3)

Port Z is an 4-bit general-purpose I/O port (P50 and P51 are used for output only). I/O is set using control register PZCR and PZFC. Resetting resets all bits of the output latch PZ to 1.

In addition to functioning as a general-purpose I/O port, port Z also functions as I/O for the CPU's control/status signal.

When PZ0 pin is defined as  $\overline{RD}$  strobe signal output mode ( $\langle PZ0F \rangle = 1$ ), clearing the output latch register  $\langle PZ0 \rangle$  to 0 outputs the  $\overline{RD}$  strobe (Used for the peused static RAM) from the PZ0 pin even when the internal addressed. If the output latch register  $\langle PZ0 \rangle$  remains 1, the  $\overline{RD}$  strobe signal is output only when the external address are is accessed.

Resetting initializes PZ2 and PZ3 pins to input mode with pull-up resistor.

Setting the AM1 and AM0 pins as shown below and resetting the device initialize PZ0 and PZ1 pins to the following function pins.

| AM1   | AM0   | PZ0F | Function Setting after Reset is Released |                        |  |
|-------|-------|------|------------------------------------------|------------------------|--|
| AIVII | AIVIO | PZ1F | PZ0 function                             | PZ1 function           |  |
| 0     | 0     | 1    | RD pin                                   | WR pin                 |  |
| 0     | 1     | 1    | RD pin                                   | WR pin                 |  |
| 1     | 0     | -    | Don't use this setting                   | Don't use this setting |  |
| 1     | 1     | 0    | Output port                              | Output port            |  |



Figure 3.5.11 Port Z (PZ0)



Figure 3.5.12 Port Z (PZ1, PZ2)



Figure 3.5.13 Port Z (PZ3)



Figure 3.5.14 Register for Port Z

## 3.5.7 Port 5 (P56)

Port 5 is an 1-bit general-purpose I/O port. I/O is set using control register P5CR and P5FC. Resetting resets all bits of the output latch P5 to P1.

In addition to functioning as a general-purpose I/O port, port 5 also functions as I/O for the CPU's control/status signal.

Resetting initializes P56 pins to input mode with pull-up resistor.



Figure 3.5.15 Port 5 (P56)



Note: When the P53/WAIT pin is to be use as the WAIT pin, P5CR<P53C> must be set to 0 and <BnW2:0> in the chip select/wait control register must be set 010.

Figure 3.5.16 Register for Port 5

#### Port 6 (P60 to P67) 3.5.8

Р6

(0015H)

P6FC2 (001BH)

Port 60 to 67 are 8-bit output ports. Resetting sets output latch of P62 to 0 and output latches of P60 to P61 and P63 to P67 are set to 1.

Port 6 also function as chip-select output ( $\overline{\text{CS0}}$  to  $\overline{\text{CS3}}$ ), extend address output (EA24, EA25), extend chip-select output ( $\overline{\text{CS2A}}$ ,  $\overline{\text{CS2B}}$ ,  $\overline{\text{CS2C}}$ ,  $\overline{\text{CS2D}}$ ,  $\overline{\text{CS2E}}$ ), SRAM byte control output (SRUB, SRLB), and SDRAM chip-select output (SDCS).

Writing 1 in the corresponding bit of P6FC, P6FC2 enables the respective functions. Resetting reset the P6FC and P6FC2 to 0, and sets all bits to output ports.



Figure 3.5.17 Port 6

#### Port 6 Register 6 0 Bit symbol P67 P66 P65 P64 P63 P62 P61 P60 (0012H) Read/Write R/W 0 After reset Port 6 Function Register P6FC

| I |             | 7                  | 6                  | 5                  | 4                  | 3                            | 2                            | 1                            | 0                            |
|---|-------------|--------------------|--------------------|--------------------|--------------------|------------------------------|------------------------------|------------------------------|------------------------------|
|   | Bit symbol  | P67F               | P66F               | P65F               | P64F               | P63F                         | P62F                         | P61F                         | P60F                         |
|   | Read/Write  |                    |                    |                    | V                  | V                            |                              |                              |                              |
|   | After reset |                    |                    |                    | (                  | )                            |                              |                              |                              |
|   | Function    | 0: Port<br>1: SRUB | 0: Port<br>1: SRLB | 0: Port<br>1: EA25 | 0: Port<br>1: EA24 | 0: Port<br>1: <del>CS3</del> | 0: Port<br>1: <del>CS2</del> | 0: Port<br>1: <del>CS1</del> | 0: Port<br>1: <del>CS0</del> |

|             | Port 6 Function Register 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |       |       |   |       |       |   |  |  |  |  |  |  |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|-------|-------|---|-------|-------|---|--|--|--|--|--|--|
|             | 7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 6     | 5     | 4     | 3 | 2     | 1     | 0 |  |  |  |  |  |  |
| Bit symbol  | P67F2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | P66F2 | P65F2 | P64F2 | - | P62F2 | P61F2 | - |  |  |  |  |  |  |
| Read/Write  | W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |       |       |       |   |       |       |   |  |  |  |  |  |  |
| After reset |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0     |       |       |   |       |       |   |  |  |  |  |  |  |
| Function    | 0: <p67f> 0: <p66f> 0: <p65f> 0: <p64f> Always 0: <p62f> 0: <p61f> Always 0: <p62f> 0: <p61f> Always write "0". 1: \overline{CS2E} C</p61f></p62f></p61f></p62f></p64f></p65f></p66f></p67f> |       |       |       |   |       |       |   |  |  |  |  |  |  |

Note: Read-modify-write is prohibited for P6FC and P6FC2.

Figure 3.5.18 Register for Port 6

## 3.5.9 Port 7 (P70 to P77)

Port 7 is an 8-bit general-purpose I/O port. I/O can be set on bit basis using the control register. Resetting sets port 7 to input port and all bits of output latch to 1.

In addition to functioning as a general-purpose I/O port, port 7 also functions as follows.

- 1. Input/output function for serial bus interface (SCK, SO/SDA, SI/SCL)
- 2. Input/output function for IrDA (OPTRX0, OPTTX0)
- 3. Extend chip-select output ( $\overline{\text{CS2F}}$ ,  $\overline{\text{CS2G}}$ ,  $\overline{\text{CSEXA}}$ )
- 4. Clock control function for voltage booster of external LCD driver (MSK, VEECLK)

Writing 1 in the corresponding bit of P7FC, P7FC2 enables the respective functions. Resetting resets the P7FC, P7FC2 to 0, and sets all bits to input ports.

## (1) Port 70 (SCK, OPTRX0)

Port 70 is a general-purpose I/O port. It is also used as SCK (Clock signal for SIO mode) and OPTRX0 (Receive input for IrDA mode of SIO0).

Used as OPTRX0, it is possible to logical invert by P7<P70>.

For port C1, RXD0 or OPTRX0 is used P7FC2<P70F2>.



Figure 3.5.19 Port 70

#### (2) Port 71 (SO/SDA/OPTTX0)

Port 71 is a general-purpose I/O port. It is also used as SDA (Data input for I<sup>2</sup>C bus mode), SO (Data output for SIO mode) for serial bus interface and OPTTX0 (Transmit output for IrDA mode of SIO0).

Used as OPTTX0, it is possible to logical invert by P7<P71>.



Figure 3.5.20 Port 71

## (3) Port 72 (SI/SCL)

Port 72 is a general-purpose I/O port. It is also used as SI (Data input for SIO mode), SCL (Clock input/output for I<sup>2</sup>C bus mode) for serial bus interface.



Figure 3.5.21 Port 72

## (4) Port 73 ( $\overline{\text{CS2F}}$ ), 74 ( $\overline{\text{CS2G}}$ ), 75 ( $\overline{\text{CSEXA}}$ )

Port 73 to 75 are general-purpose I/O ports. These are also used as control signal for sequential mask ROM and extend chip-select output.



Figure 3.5.22 Port 73, 74, 75

## (5) Port 76 (MSK), 77 (VEECLK)

Port 76 and 77 are general-purpose I/O ports. These are also used as clock control function for voltage booster of external LCD driver.

MSK pin (P76) is an input pin from external LCD driver, clock output from VEECLK pin is controlled by state of this pin. Logic of this pin is controlled with P7FC<P76F>.

VEECLK pin outputs clock of 32 kHz for voltage booster or 0 level according to request from MSK pin. VEECLK output is controlled with P7FC<P77F>.



Figure 3.5.23 Port 76, 77

|         |             |              |            | Po               | ort 7 Register   |                  |                 |                  |              |
|---------|-------------|--------------|------------|------------------|------------------|------------------|-----------------|------------------|--------------|
| •       |             | 7            | 6          | 5                | 4                | 3                | 2               | 1                | 0            |
| P7      | Bit symbol  | P77          | P76        | P75              | P74              | P73              | P72             | P71              | P70          |
| (0013H) | Read/Write  |              |            |                  | R/               | W                |                 |                  |              |
|         | After reset |              | Da         | ita from exte    | rnal port (Out   | put latch reg    | ister is set to | 1.)              |              |
|         |             |              |            | Port 7           | Control Regi     | ster             |                 |                  |              |
|         |             | 7            | 6          | 5                | 4                | 3                | 2               | 1                | 0            |
| P7CR    | Bit symbol  | P77C         | P76C       | P75C             | P74C             | P73C             | P72C            | P71C             | P70C         |
| (0016H) | Read/Write  |              |            |                  | V                | V                |                 |                  |              |
|         | After reset | 0            | 0          | 0                | 0                | 0                | 0               | 0                | 0            |
|         | Function    |              |            | 0: I             | nput             | 1։ Օւ            | utput           |                  |              |
|         |             |              |            | Port 7           | Function Reg     | ister            |                 |                  |              |
|         |             | 7            | 6          | 5                | 4                | 3                | 2               | 1                | 0            |
| P7FC    | Bit symbol  | P77F         | P76F       | P75F             | P74F             | P73F             | P72F            | P71F             | P70F         |
| (0017H) | Read/Write  |              |            |                  | V                | V                |                 |                  |              |
|         | After reset |              |            | _                | (                | )                |                 | _                |              |
|         | Function    | 0:Port       | MSK        | 0: Port          | 0: Port          | 0: Port          | 0: Port         | 0: Port          | 0: Port      |
|         |             | 1:VEECLK     | select     |                  |                  |                  | 1: SCL/SI       | 1: SDA/SO        | 1: SCK       |
|         |             |              | 0: Enable  |                  |                  |                  |                 |                  |              |
|         |             |              | 1: Enable  |                  |                  |                  |                 |                  |              |
|         |             |              |            |                  | unction Regis    |                  |                 |                  |              |
|         |             | 7            | 6          | 5                | 4                | 3                | 2               | 1                | 0            |
| P7FC2   | Bit symbol  | =            | =          | P75F2            | P74F2            | P73F2            | _               | P71F2            | P70F2        |
| (001CH) | Read/Write  |              |            |                  | V                | V                |                 |                  |              |
|         | After reset |              | ,          | ·                | C                | )                |                 | r                |              |
|         | Function    | Always       | Always     | 0: <p75f></p75f> | 0: <p74f></p74f> | 0: <p73f></p73f> | Always write    | 0: <p71f></p71f> | SIO0/RXD0    |
|         |             | write "0".   | write "0". | 1: CSEXA         | 1: CS2G          | 1: CS2F          | "0".            | 1: OPTTX0        | Pin select   |
|         |             |              |            |                  |                  |                  |                 |                  | 0: RXD0(PC1) |
|         |             |              |            |                  |                  |                  |                 |                  | 1: OPTRX0    |
|         |             |              |            |                  |                  |                  |                 |                  | (P70)        |
|         |             |              |            | Port             | 7 ODE Regis      | ter              |                 |                  |              |
|         |             | 7            | 6          | 5                | 4                | 3                | 2               | 1                | 0            |
| P7ODE   | Bit symbol  | _            | _          |                  |                  |                  | ODEP72          | ODEP71           |              |
| (001FH) | Read/Write  | V            | V          |                  |                  |                  | V               | V                |              |
| ĺ       | After reset | 0            | 0          |                  |                  |                  | 0               | 0                |              |
|         | Function    | Always write | "0".       |                  |                  |                  | 0: 3 states     |                  |              |

Note: Read-modify-write is prohibited for P7CR, P7FC, P7FC2 and P7ODE.

Figure 3.5.24 Register for Port 7

1: Open drain

# 3.5.10 Port 8 (P80 to P87)

Port 8 is an 8-bit input port and can also be used as the analog input pins for the internal AD converter. P83 can also be used as ADTRG pin for the AD converter.



Figure 3.5.25 Port 8

Port 8 Register

P8 (0018H)

|    |             | 7   | 6                       | 5   | 4   | 3   | 2   | 1   | 0   |  |  |  |  |
|----|-------------|-----|-------------------------|-----|-----|-----|-----|-----|-----|--|--|--|--|
|    | Bit symbol  | P87 | P86                     | P85 | P84 | P83 | P82 | P81 | P80 |  |  |  |  |
| 1) | Read/Write  |     |                         |     | F   | ₹   |     |     |     |  |  |  |  |
|    | After reset |     | Data from external port |     |     |     |     |     |     |  |  |  |  |

Note: The input channel selection of AD converter and the permission of ADTRG input are set by AD converter mode register ADMOD1.

Figure 3.5.26 Register for Port 8

## 3.5.11 Port 9 (P90 to P97)

Port 90 to 97 are 8-bit input ports with pull-up resistor. In addition to functioning as general-purpose I/O port, port 90 to 97 can also key-on wakeup function as keyboard interface. The various functions can each be enabled by writing a 1 to the corresponding bit of the port 9 function register (P9FC).

Resetting resets all bits of the register P9FC to 0 and sets all pins to be input port.



Figure 3.5.27 Port 9

When P9FC = 1, if either of input of KI0 to KI7 pins falls down, INTKEY interrupt is generated. INTKEY interrupt can be used to release all HALT mode.



Figure 3.5.28 Register for Port 9

# 3.5.12 Port A (PA0 to PA7)

Port PA0 to PA7 are 8-bit output ports, and also used key board interface pin KO0 to KO7 which can set open-drain output buffer.

Writing 1 in the corresponding bit of the port A function register (PAFC) enable the open-drain output.

Resetting reset bits of the registers PA to 1 and PAFC to 0, and all pin outputs 1.



Figure 3.5.29 Port A

|         |             |      |      | Port A      | Register      |           |       |      |      |
|---------|-------------|------|------|-------------|---------------|-----------|-------|------|------|
|         |             | 7    | 6    | 5           | 4             | 3         | 2     | 1    | 0    |
| PA      | Bit symbol  | PA7  | PA6  | PA5         | PA4           | PA3       | PA2   | PA1  | PA0  |
| (001EH) | Read/Write  |      |      |             | R/            | W         |       |      |      |
|         | After reset | 1    | 1    | 1           | 1             | 1         | 1     | 1    | 1    |
|         |             |      |      | Port A Fund | tion Register |           |       |      |      |
|         |             | 7    | 6    | 5           | 4             | 3         | 2     | 1    | 0    |
| PAFC    | Bit symbol  | PA7F | PA6F | PA5F        | PA4F          | PA3F      | PA2F  | PA1F | PA0F |
| (0021H) | Read/Write  |      |      |             | V             | V         |       |      |      |
|         | After reset | 0    | 0    | 0           | 0             | 0         | 0     | 0    | 0    |
|         | Function    |      |      | 0: C        | MOS output    | 1: Open o | Irain |      |      |

Note: Read-modify-write is prohibited for PAFC.

Figure 3.5.30 Register for Port A

TOSHIBA

## 3.5.13 Port B (PB0 to PB6)

Port B is a 6-bit general-purpose I/O port. Each bit can be set individually for input or output. Resetting sets port B to be an input port.

In addition to functioning as a general-purpose I/O port, port B can also function as I/O pin for timers (TA0IN, TA1OUT, TA3OUT, TB0OUT0), input pin for external interruption (INT0 to INT3), and I/O for serial channels 2 (TXD2, RXD2). Above setting is used the function register PBFC and PBFC2. Edge select of external interruption establishes it with IIMC register, which there is in interruption controller.

#### (1) PB0 (TA0IN, TXD2)

As well as functioning as I/O port pins, port B0 can also function as serial channel TXD output pins. In case of use TXD2, it is possible to logical invert by setting the register PB<PB0>.

And port B0 has a programmable open-drain function which can be control the register PBODE<ODEPB0>.



Figure 3.5.31 Port B0

## (2) PB1 (TA1OUT, RXD2)

Port B1 is I/O port pins and can also is used as RXD input for the serial channels. In case of use RXD2, it is possible to logical invert by setting the register PB<PB1>.



Figure 3.5.32 Port B1



Figure 3.5.33 Port B3

## (4) PB4 (INT1), PB5 (INT2, TA3OUT), PB6 (INT3, TB0OUT0)





Figure 3.5.34 PB4 to PB6



Note 1: Read-modify-write is prohibited for the registers PBCR, PBFC and PBODE.

Note 2: PB0/TA0IN pin does not have a register changing PORT/FUNCTION.

For example, when it is used as an input port, the input signal is inputted to 8-bit timer.

Note 3: PB1/RXD1 pin does not have a register changing PORT/FUNCTION.

For example, when it is used as an input port, the input signal is inputted to SIO as the serial receive data.

Figure 3.5.35 Register for Port B

## 3.5.14 Port C (PC0 to PC5)

Port C0 to C5 are 6-bit general-purpose I/O ports. Each bit can be set individually for input or output. Resetting sets PC0 to PC5 to be an input ports. It also sets all bits of the output latch register to 1.

In addition to functioning as general-purpose I/O port pins, PC0 to PC5 can also function as the I/O for serial channels 0 and 1. A pin can be enabled for I/O by writing a 1 to the corresponding bit of the port C function register (PCFC).

Resetting resets all bits of the registers PCCR and PCFC to 0 and sets all pins to be input ports.

#### (1) Port C0, C3 (TXD0/TXD1)

As well as functioning as I/O port pins, port C0 and C3 can also function as serial channel TXD output pins. In case of use TXD0/TXD1, it is possible to logical invert by setting the register PC<PC0, 3>.

And ports C0 to C3 have a programmable open-drain function, which can be control the register PCODE<ODEPC0, 3>.



Figure 3.5.36 Port C0 and Port C3

## (2) Port C1, C4 (RXD0, 1)

Port C1 and C4 are I/O port pins and can also be used as RXD input for the serial channels. In case of use RXD0/RXD1, it is possible to logical invert by setting the register PC<PC1, 4>.

And input data of SIO0 can be select from RXD/PC1 pin or OPTRX0/P70 by setting the register PCFC2<P70F2>.



Figure 3.5.37 Port C1 and Port C4

#### (3) Port C2 (CTSO, SCLKO), C5 (CTSI, SCLK1)

Port C2 and C4 are I/O port pins and can also be used as  $\overline{\text{CTS}}$  input or SCLK input/output for the serial channels. In case of use  $\overline{\text{CTS}}$ , SCLK, it is possible to logical invert by setting the register PC<PC2, 5>.



Figure 3.5.38 Port C2 and Port C5

|         |                      |   |   | Po       | rt C Register |               |               |                 |         |  |  |
|---------|----------------------|---|---|----------|---------------|---------------|---------------|-----------------|---------|--|--|
|         |                      | 7 | 6 | 5        | 4             | 3             | 2             | 1               | 0       |  |  |
| PC      | Bit symbol           |   |   | PC5      | PC4           | PC3           | PC2           | PC1             | PC0     |  |  |
| (0023H) | Read/Write           | / |   |          |               | R/            | W             |                 |         |  |  |
|         | After reset          |   |   | Da       | ta from exter | nal port (Out | put latch reg | ister is set to | 1.)     |  |  |
|         |                      |   |   | Port C   | Control Regi  | ster          |               |                 |         |  |  |
|         |                      | 7 | 6 | 5        | 4             | 3             | 2             | 1               | 0       |  |  |
| PCCR    | Bit symbol           |   |   | PC5C     | PC4C          | PC3C          | PC2C          | PC1C            | PC0C    |  |  |
| (0026H) | (0026H) Read/Write W |   |   |          |               |               |               |                 |         |  |  |
|         | After reset          |   |   | 0        | 0             | 0             | 0             | 0               | 0       |  |  |
|         | Function             |   |   |          |               | 0: Input      | 1: Output     |                 |         |  |  |
|         |                      |   |   | Port C   | Functon Reg   | ister         |               |                 |         |  |  |
|         |                      | 7 | 6 | 5        | 4             | 3             | 2             | 1               | 0       |  |  |
| PCFC    | Bit symbol           |   |   | PC5F     |               | PC3F          | PC2F          |                 | PC0F    |  |  |
| (0027H) | Read/Write           |   |   | W        |               | W             | W             |                 | W       |  |  |
|         | After reset          |   |   | 0        |               | 0             | 0             |                 | 0       |  |  |
|         | Function             |   |   | 0: Port  |               | 0: Port       | 0: Port       |                 | 0: Port |  |  |
|         |                      |   |   | 1: SCLK1 |               | 1: TXD1       | 1: SCLK0      |                 | 1: TXD0 |  |  |
|         |                      |   |   | output   |               |               | output        |                 |         |  |  |
|         |                      |   |   | Port (   | ODE Regis     | ter           |               |                 | _       |  |  |
|         |                      | 7 | 6 | 5        | 4             | 3             | 2             | 1               | 0       |  |  |
| PCODE   | Bit symbol           |   |   |          |               | ODEPC3        |               |                 | ODEPC0  |  |  |
| (0028H) | Read/Write           |   |   |          |               | W             |               |                 | W       |  |  |
|         | After reset          |   |   |          |               | 0             |               |                 | 0       |  |  |
|         | Function             |   |   |          |               | TXD1          |               |                 | TXD0    |  |  |
|         |                      |   |   |          |               | 0: CMOS       |               |                 | 0: CMOS |  |  |
|         |                      |   |   |          |               | 1: Open       |               |                 | 1: Open |  |  |
|         |                      |   |   |          |               | drain         |               |                 | drain   |  |  |

Note 1: Read-modify-write is prohibited for the registers PCCR, PCFC and PCODE.

Note 2: PC1/RXD0, PC4/RXD1 pins do not have a register changing PORT/FUNCTION. For example, when it is used as an input port, the input signal is inputted to SIO as the serial receive data.

Figure 3.5.39 Register for Port C

## 3.5.15 Port D (PD0 to PD7)

Port D is an 8-bit output port. Resetting sets the output latch PD to 1, and PD0 to PD7 pin output 1.

In addition to functioning as output port, port D also function as output pin for LCD controller (DIBSCP, D2BLP, D3BFR, DLEBCD and DOFFB), output pin for RTC alarm ( $\overline{ALARM}$ ) and output pin for melody/alarm generator (MLDALM,  $\overline{MLDALM}$ ). Above setting is used the function register PDFC.

Only PD6 has two output function which are  $\overline{ALARM}$  and  $\overline{MLDALM}$ . This selection is used PD<PD6>. Resetting resets the function register PDFC to 0, and sets all ports to output ports.



Figure 3.5.40 Port D0 to D4, D7



Figure 3.5.41 Port D6

Port D Register

|         |             | 7         | 6                                | 5           | 4            | 3         | 2        | 1        | 0         |
|---------|-------------|-----------|----------------------------------|-------------|--------------|-----------|----------|----------|-----------|
| PD      | Bit symbol  | PD7       | PD6                              |             | PD4          | PD3       | PD2      | PD1      | PD0       |
| (0029H) | Read/Write  | R/        | W                                |             |              |           | R/W      |          |           |
|         | After reset | 1         | 1                                |             | 1            | 1         | 1        | 1        | 1         |
|         |             |           |                                  | Port D Fund | tion Registe | r         |          |          |           |
|         |             | 7         | 6                                | 5           | 4            | 3         | 2        | 1        | 0         |
| PDFC    | Bit symbol  | PD7F      | PD6F                             |             | PD4F         | PD3F      | PD2F     | PD1F     | PD0F      |
| (002AH) | Read/Write  | V         | ٧                                |             |              |           | W        |          |           |
|         | After reset | (         | )                                |             |              |           | 0        |          |           |
|         | Function    |           | 0: Port<br>1: ALARM              |             | 0: Port      | 0: Port   | 0: Port  | 0: Port  | 0: Port   |
|         |             | 1: MLDALM | at <pd6> = 1<br/>1: MLDALM</pd6> |             | 1: DOFFB     | 1: DLEBCD | 1: D3BFR | 1: D2BLP | 1: D1BSCP |

Note: Read-modify-write is prohibited for the registers PDFC.

Figure 3.5.42 Register for Port D

## 3.5.16 Port E (PE0 to PE7)

Port E is an 8-bit general-purpose I/O ports. Each bit can be set individually for input or output using the control register PECR. Resetting, the control register PECR to 0 and sets Port E to input ports. It also sets all bits of the output latch register to 1.

In addition to functioning as a general-purpose I/O port, port E can also function as an data bus for LCD controller (LD0 to LD7). Above setting is used the function register PEFC.



Figure 3.5.43 Port E

|         |             |                    |      | Port E        | Register       |                |                 |      |      |  |  |  |
|---------|-------------|--------------------|------|---------------|----------------|----------------|-----------------|------|------|--|--|--|
|         |             | 7                  | 6    | 5             | 4              | 3              | 2               | 1    | 0    |  |  |  |
| PE      | Bit symbol  | PE7                | PE6  | PE5           | PE4            | PE3            | PE2             | PE1  | PE0  |  |  |  |
| (002CH) | Read/Write  |                    |      |               | R/             | W              |                 |      |      |  |  |  |
|         | After reset |                    | Da   | ta from exter | nal port (Out  | put latch regi | ister is set to | 1.)  |      |  |  |  |
|         |             |                    |      | Port E Con    | trol Register  |                |                 |      |      |  |  |  |
|         |             | 7                  | 6    | 5             | 4              | 3              | 2               | 1    | 0    |  |  |  |
| PECR    | Bit symbol  | PE7C               | PE6C | PE5C          | PE4C           | PE3C           | PE2C            | PE1C | PE0C |  |  |  |
| (002DH) | Read/Write  | W                  |      |               |                |                |                 |      |      |  |  |  |
|         | After reset | 0                  | 0    | 0             | 0              | 0              | 0               | 0    | 0    |  |  |  |
|         | Function    | 0: Input 1: Output |      |               |                |                |                 |      |      |  |  |  |
|         |             |                    |      | Port E Fund   | tion Register  | r              |                 |      |      |  |  |  |
|         |             | 7                  | 6    | 5             | 4              | 3              | 2               | 1    | 0    |  |  |  |
| PEFC    | Bit symbol  | PE7F               | PE6F | PE5F          | PE4F           | PE3F           | PE2F            | PE1F | PE0F |  |  |  |
| (002EH) | Read/Write  |                    |      |               | V              | V              |                 |      |      |  |  |  |
|         | After reset | 0                  | 0    | 0             | 0              | 0              | 0               | 0    | 0    |  |  |  |
|         | Function    |                    |      | 0: Port       | 1: Data bus fo | or LCDC (LD    | 7 to LD0)       |      |      |  |  |  |

Note: Read-modify-write is prohibited for PECR and PEFC.

Figure 3.5.44 Register for Port E

## 3.5.17 Port F (PF0 to PF7)

Port F is an 8-bit output port. Resetting sets the output latch PF to 1, and PF0 to PF7 pin output 1.

In addition to functioning as output port, port F also function as output pin for SDRAM controller (SDCKE, SDCLK, SDLDQM, SDUDQM, SDWE), and output pin for SSIO (SSCLK). Above setting is used the function register PFFC.



Figure 3.5.45 Port F

|         |             |              |          | Port F      | Register       |           |         |          |          |
|---------|-------------|--------------|----------|-------------|----------------|-----------|---------|----------|----------|
|         |             | 7            | 6        | 5           | 4              | 3         | 2       | 1        | 0        |
| PF      | Bit symbol  | PF7          | PF6      | PF5         | PF4            | PF3       | PF2     | PF1      | PF0      |
| (0030H) | Read/Write  |              |          |             | R/             | W         |         |          |          |
|         | After reset | 1            | 1        | 1           | 1              | 1         | 1       | 1        | 1        |
|         |             |              |          | Port F Fund | ction Register | r         |         |          |          |
|         |             | 7            | 6        | 5           | 4              | 3         | 2       | 1        | 0        |
| PFFC    | Bit symbol  | =            | PF6F     | PF5F        | PF4F           | PF3F      | PF2F    | PF1F     | PF0F     |
| (0032H) | Read/Write  |              |          |             | V              | V         |         |          |          |
|         | After reset | 0            | 1        | 0           | 0              | 0         | 0       | 0        | 0        |
|         | Function    | Always write | 0: Port  | 0: Port     | 0: Port        | 0: Port   | 0: Port | 0: Port  | 0: Port  |
|         |             | "0".         | 1: SDCLK | 1: SDCKE    | 1: SDUDQM      | 1: SDLDQM | 1: SDWE | 1: SDCAS | 1: SDRAS |

Note: Read-modify-write is prohibited for the registers PFFC.

Figure 3.5.46 Register for Port F

## 3.6 Chip Select/Wait Controller

On the TMP91C820A, four user-specifiable address areas ( $\overline{\text{CS0}}$  to  $\overline{\text{CS3}}$ ) can be set. The data bus width and the number of waits can be set independently for each address area ( $\overline{\text{CS0}}$  to  $\overline{\text{CS3}}$  and others).

The pins  $\overline{\text{CS0}}$  to  $\overline{\text{CS3}}$  (which can also function as port pins P60 to P63) are the respective output pins for the areas CS0 to CS3. When the CPU specifies an address in one of these areas, the corresponding  $\overline{\text{CS0}}$  to  $\overline{\text{CS3}}$  pin outputs the chip select signal for the specified address area (in ROM or SRAM). However, in order for the chip select signal to be output, the port 6 function register (P6FC) must be set.

 $\overline{\text{CS2A}}$  to  $\overline{\text{CS2G}}$  and  $\overline{\text{CSEXA}}$  (CS pin except  $\overline{\text{CS0}}$  to  $\overline{\text{CS3}}$ ) are made by MMU.

These pins are  $\overline{CS}$  pin that area and BANK value is fixed without concern in setting of CS/WAIT controller.

The areas CS0 to CS3 are defined by the values in the memory start address registers MSAR0 to MSAR3 and the memory address mask registers MAMR0 to MAMR3.

The chip select/wait control registers B0CS to B3CS and BEXCS should be used to specify the master enable/disable status the data bus width and the number of waits for each address area. The input pin controlling these states is the bus wait request pin ( $\overline{\text{WAIT}}$ ).

#### 3.6.1 Specifying an Address Area

The CS0 to CS3 address areas are specified using the start address registers (MSAR0 to MSAR3) and memory address mask registers (MAMR0 to MAMR3).

At each bus cycle, a compare operation is performed to determine if the address on the specified a location in the CS0 to CS3 area. If the result of the comparison is a match, this indicates an access to the corresponding CS area. In this case, the  $\overline{\text{CS0}}$  to  $\overline{\text{CS3}}$  pin outputs the chip select signal and the bus cycle operates in accordance with the settings in chip select/wait control register B0CS to B3CS. (See 3.6.2 "Chip Select/Wait Control Registers".)

#### (1) Memory start address registers

Figure 3.6.1 shows the memory start address registers. The memory start address registers MSAR0 to MSAR3 set the start addresses for the CS0 to CS3 areas. Set the upper eight bits (A23 to A16) of the start address in <S23:16>. The lower 16 bits of the start address (A15 to A0) are permanently set to 0. Accordingly, the start address can only be set in 64-Kbyte increments, starting from 000000H. Figure 3.6.2 shows the relationship between the start address and the start address register value.

|                  |             | 7   | 6   | 5      | 4             | 3              | 2            | 1            | 0           |
|------------------|-------------|-----|-----|--------|---------------|----------------|--------------|--------------|-------------|
| MSAR0 /MSAR1     | Bit symbol  | S23 | S22 | S21    | S20           | S19            | S18          | S17          | S16         |
| (00C8H)/ (00CAH) | Read/Write  |     |     |        | R/            | W              |              |              |             |
| MSAR2 /MSAR3     | After reset | 1   | 1   | 1      | 1             | 1              | 1            | 1            | 1           |
| (00CCH)/ (00CEH) | Function    |     |     | Determ | ines A23 to A | A16 of start a | ddress.      |              |             |
| •                |             |     |     |        | •             |                |              |              |             |
|                  |             |     |     |        | I             | → Sets s       | tart address | es for areas | CS0 to CS3. |

Memory Start Address Registers (for areas CS0 to CS3)

Figure 3.6.1 Memory Start Address Register



Figure 3.6.2 Relationship between Start Address and Start Address Register Value

**TOSHIBA** 

#### (2) Memory address mask registers

Figure 3.6.3 shows the memory address mask registers. Memory address mask registers MAMR0 to MAMR3 are used to set the size of the CS0 to CS3 areas by specifying a mask for each bit of the start address set in memory start address registers MAMR0 to MAMR3. The compare operation used to determine if an address is in the CS0 to CS3 areas is only performed for bus address bits corresponding to bits set to 0 in these registers. Also, the address bits that can be masked by MAMR0 to MAMR3 differ between CS0 to CS3 areas. Accordingly, the size that can be each area is different.

Memory Address Mask Register (for CS0 area)

|         |             | 7   | 6   | 5             | 4      | 3             | 2            | 1         | 0  |  |  |  |  |
|---------|-------------|-----|-----|---------------|--------|---------------|--------------|-----------|----|--|--|--|--|
| MAMR0   | Bit symbol  | V20 | V19 | V18           | V17    | V16           | V15          | V14 to V9 | V8 |  |  |  |  |
| (00C9H) | Read/Write  |     | R/W |               |        |               |              |           |    |  |  |  |  |
|         | After reset | 1   | 1   | 1             | 1      | 1             | 1            | 1         | 1  |  |  |  |  |
|         | Function    |     | Se  | ts size of CS | 0 area | : Used for ad | ldress compa | are       |    |  |  |  |  |

Range of possible settings for CS0 area size: 256 bytes to 2 Mbytes

#### Memory Address Mask Register (CS1)

|         |             | 7                                                 | 6   | 5   | 4   | 3   | 2   | 1         | 0  |  |  |  |  |
|---------|-------------|---------------------------------------------------|-----|-----|-----|-----|-----|-----------|----|--|--|--|--|
| MAMR1   | Bit symbol  | V21                                               | V20 | V19 | V18 | V17 | V16 | V15 to V9 | V8 |  |  |  |  |
| (00CBH) | Read/Write  |                                                   | R/W |     |     |     |     |           |    |  |  |  |  |
|         | After reset | 1                                                 | 1   | 1   | 1   | 1   |     |           |    |  |  |  |  |
|         | Function    | Sets size of CS1 area 0: Used for address compare |     |     |     |     |     |           |    |  |  |  |  |

Range of possible settings for CS1 area size: 256 bytes to 4 Mbytes.

#### Memory Address Mask Register (CS2, CS3)

|                  |                                                             | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |  |  |  |  |
|------------------|-------------------------------------------------------------|-----|-----|-----|-----|-----|-----|-----|-----|--|--|--|--|
| MAMR2 /MAMR3     | Bit symbol                                                  | V22 | V21 | V20 | V19 | V18 | V17 | V16 | V15 |  |  |  |  |
| (00CDH)/ (00CFH) | Read/Write                                                  | R/W |     |     |     |     |     |     |     |  |  |  |  |
|                  | After reset                                                 | 1   | 1   | 1   | 1   | 1   | 1   | 1   | 1   |  |  |  |  |
|                  | Function Sets size of CS2 or CS3 area 0: Used for address c |     |     |     |     |     |     |     |     |  |  |  |  |

Range of possible settings for CS2 and CS3 area sizes: 32 Kbytes to 8 Mbytes.

Figure 3.6.3 Memory Address Mask Registers

(3) Setting memory start addresses and address areas

Figure 3.6.4 shows an example of specifying a 64-Kbyte address area starting from 010000H using the CS0 areas.

Set 01H in memory start address register MSAR0<S23:16> (Corresponding to the upper 8 bits of the start address). Next, calculate the difference between the start address and the anticipated end address (01FFFFH) based on the size of the CS0 area. Bits 20 to 8 of the result correspond to the mask value to be set for the CS0 area. Setting this value in memory address mask register MAMR0<V20:8> sets the area size. This example sets 07H in MAMR0 to specify a 64K-byte area.



Figure 3.6.4 Example Showing How to Set the CS0 Area

After a reset, MSAR0 to MSAR3 and MAMR0 to MAMR3 are set to FFH. B0CS<B0E>, B1CS<B1E> and B3CS<B3E> are reset to 0. This disabling the CS0, CS1 and CS3 areas. However, as B2CS<B2M> to 0 and B2CS<B2E> to 1, CS2 is enabled from 000FE0H to 000FFFH and 003000H to FFFFFFH in TMP91C820A. Also, the bus width and number of waits specified in BEXCS are used for accessing addresses outside the specified CS0 to CS3 area. (See 3.6.2 "Chip Select/Wait Control Registers".)

## (4) Address area size specification

Table 3.6.1 shows the relationship between CS area and area size. " $\Delta$ " indicates areas that cannot be set by memory start address register and address mask register combinations. When setting an area size using a combination indicated by " $\Delta$ ", set the start address mask register in the desired steps starting from 000000H.

If the CS2 area is set to 16 Mbytes or if two or more areas overlap, the smaller CS area number has the higher priority.

Example: To set the area size for CS0 to 128 Kbytes:

#### a. Valid start addresses



#### b. Invalid start addresses



Table 3.6.1 Valid Area Sizes for Each CS Area

| Size (bytes)<br>CS area | 256 | 512 | 32 K | 64 K | 128 K | 256 K | 512 K | 1 M | 2 M | 4 M | 8 M |
|-------------------------|-----|-----|------|------|-------|-------|-------|-----|-----|-----|-----|
| CS0                     | 0   | 0   | 0    | 0    | Δ     | Δ     | Δ     | Δ   | Δ   |     |     |
| CS1                     | 0   | 0   |      | 0    | Δ     | Δ     | Δ     | Δ   | Δ   | Δ   |     |
| CS2                     |     |     | 0    | 0    | Δ     | Δ     | Δ     | Δ   | Δ   | Δ   | Δ   |
| CS3                     |     |     | 0    | 0    | Δ     | Δ     | Δ     | Δ   | Δ   | Δ   | Δ   |

Note: "Δ" indicates areas that cannot be set by memory start address register and address mask register combinations.

#### 3.6.2 Chip Select/Wait Control Registers

Figure 3.6.5 lists the chip select/wait control registers.

The master enable/disable, chip select output waveform, data bus width and number of wait states for each address area (CS0 to CS3 and others) are set in their respective chip select/wait control registers, B0CS to B3CS and BEXCS.

#### Chip Select/Wait Control Registers 6 0 B0CS B0E B0OM1 B0OM0 **B0BUS** B0W2 B0W1 B0W0 Bit symbol (00C0H) Read/Write W W After reset 0 0 0 Readmodify-0: Disable Chip select output Data bus Number of waits Function 1: Enable width 000: 2 waits waveform selection 100: Reserved write 00: For ROM/SRAM 0: 16 bits 001: 1 wait 101: 3 waits instructions 01. 1: 8 bits 010: (1 + N) waits 110: 4 waits are 10: Don't care 011: 0 waits 111: 8 waits prohibited. B1CS B1W0 B1E B1OM1 B1OM0 **B1BUS** B1W2 B1W1 Bit symbol (00C1H) Read/Write W W After reset 0 0 0 0 0 Read-0: Disable Chip select output Data bus Number of waits modify-**Function** 100: Reserved 1: Enable waveform selection width 000: 2 waits write 00: For ROM/SRAM 0: 16 bits instructions 001: 1 wait 101: 3 waits 01: 1: 8 bits 010: (1 + N) waits 110: 4 waits are 10: Don't care 011: 0 waits 111: 8 waits prohibited. B2CS B2OM0 B2BUS B2W1 B2W0 Bit symbol B<sub>2</sub>E B<sub>2</sub>M B2OM1 B2W2 (00C2H) Read/Write W After reset 0 0 0 0 0 1 0 0 Read-0: Disable CS2 area Chip select output Data bus Number of waits modify-**Function** 1: Enable selection waveform selection width 000: 2 waits 100: Reserved write 0: 16-Mbyte 00: For ROM/SRAM 0: 16 bits 001: 1 wait 101: 3 waits instructions 01: 1: 8 bits 010: (1 + N) waits 110: 4 waits are prohibited. 1: CS area 10: Don't care 011: 0 waits 111: 8 waits B3CS Bit symbol B3E B3OM1 **B3OM0 B3BUS** B3W2 B3W1 B3W0 (00C3H) Read/Write W W After reset 0 0: Disable Chip select output Data bus Number of waits Function modify-1: Enable width waveform selection 000: 2 waits 100: Reserved write 00: For ROM/SRAM 0: 16 bits 001: 1 wait 101: 3 waits instructions 010: (1 + N) waits 110: 4 waits 01: 1: 8 bits are 10: Don't care 011: 0 waits 111: 8 waits prohibited. **BEXCS BEXBUS** BEXW2 BEXW1 BEXW0 Bit symbol (00C7H) Read/Write After reset 0 0 0 Read-Data bus Number of waits modify-Function 000: 2 waits width 100: Reserved write 0: 16 bits 001: 1 wait 101: 3 waits instructions 1: 8 bits 010: (1 + N) waits 110: 4 waits are 011: 0 waits 111: 8 waits prohibited. Chip select output waveform Master enable bit selection Number of address area waits Disable (See 3.6.2 (3) "Wait control".) 00 For ROM/SRAM Enable 01 Data bus width selection 10 Don't care CS2 area selection 11 0 16-bit data bus 0 16-Mbyte area 8-bit data bus Specified address area

Figure 3.6.5 Chip Select/Wait Control Registers

#### (1) Master enable bits

Bit 7 (<B0E>, <B1E>, <B2E> or <B3E>) of a chip select/wait control register is the master bit, which is used to enable or disable settings for the corresponding address area. Writing 1 to this bit enables the settings. Reset disables (Sets to 0) <B0E>, <B1E> and <B3E>, and enabled (Sets to 1) <B2E>. This enables area CS2 only.

#### (2) Data bus width selection

Bit 3 (<B0BUS>, <B1BUS>, <B2BUS>, <B3BUS> or <BEXBUS>) of a chip select/wait control register specifies the width of the data bus. This bit should be set to 0 when memory is to be accessed using a 16-bit data bus and to 1 when an 8-bit data bus is to be used.

This process of changing the data bus width according to the address being accessed is known as dynamic bus sizing. For details of this bus operation see Table 3.6.2.

Table 3.6.2 Dynamic Bus Sizing

|                         |              | Table 3.6.2 Dynamic Bus Sizing                          |          |                       |                                                         |                       |           |                       |                            |           |                                                   |                           |                                                   |          |            |            |
|-------------------------|--------------|---------------------------------------------------------|----------|-----------------------|---------------------------------------------------------|-----------------------|-----------|-----------------------|----------------------------|-----------|---------------------------------------------------|---------------------------|---------------------------------------------------|----------|------------|------------|
|                         | SRWR         |                                                         |          |                       |                                                         |                       |           |                       | _                          |           |                                                   |                           |                                                   |          |            |            |
| cle                     | SRUB         |                                                         | I        | Н                     | _                                                       | Н                     | ٦         | Н                     | ٦                          | I         | I                                                 | ٦                         | н                                                 | ٦        | ٦          | Н          |
| Control for WRITE Cycle | SRLB         |                                                         | L        | L                     | I                                                       | L                     | Г         | Г                     | Н                          | L         | _                                                 | Γ                         | Γ                                                 | Н        | L          | L          |
| for WR                  | HWR          | :                                                       | Н        | Н                     | _                                                       | Н                     | Г         | н                     | L                          | Н         | I                                                 | Γ                         | Ι                                                 | L        | L          | Н          |
| ontrol                  | WR           | -                                                       | _        | Γ                     | I                                                       | Γ                     | ٦         | Γ                     | н                          | Γ         |                                                   | ٦                         | ٦                                                 | н        | ٦          | L          |
| 0                       | RD           | Ξ                                                       |          |                       |                                                         |                       |           |                       |                            |           |                                                   |                           |                                                   |          |            |            |
|                         | RW           |                                                         |          |                       |                                                         |                       |           |                       | _                          |           |                                                   |                           |                                                   |          |            |            |
|                         | SRWR         |                                                         |          |                       |                                                         |                       |           |                       | I                          |           |                                                   |                           |                                                   |          |            |            |
| cle                     | SRUB         | :                                                       | I        | Н                     | _                                                       | н                     | ٦         | Н                     | ٦                          | I         | I                                                 | ٦                         | т                                                 | ٦        | ٦          | Ŧ          |
| Control for READ Cycle  | SRLB         |                                                         | L        | L                     | I                                                       | L                     | Г         | ٦                     | Н                          | L         | _                                                 | ٦                         | Г                                                 | Н        | L          | L          |
| for RE                  | HWR          | ±                                                       |          |                       |                                                         |                       |           |                       |                            |           |                                                   |                           |                                                   |          |            |            |
| ontrol                  | WR           | <b>T</b>                                                |          |                       |                                                         |                       |           |                       |                            |           |                                                   |                           |                                                   |          |            |            |
|                         | RD           |                                                         |          |                       |                                                         |                       |           |                       |                            |           |                                                   |                           |                                                   |          |            |            |
|                         | R/W          |                                                         |          |                       |                                                         |                       |           |                       | I                          |           |                                                   |                           |                                                   | •        |            |            |
| Data                    | D7 to D0     | b7 to b0                                                | b7 to b0 | b7 to b0              | ×                                                       | b7 to b0<br>b15 to b8 | b7 to b0  | b7 to b0<br>b15 to b8 | XXXX                       | b15 to b8 | b7 to b0<br>b15 to b8<br>b23 to b16<br>b31 to b24 | b7 to b0<br>b23 to b16    | b7 to b0<br>b15 to b8<br>b23 to b16<br>b31 to b24 | XXXX     | b15 to b8  | b31 to b24 |
| CPU Data                | D15 to D8    | XXXX                                                    | XXXX     | XXXX                  | b7 to b0                                                | XXXX                  | b15 to b8 | XXXX                  | b7 to b0                   | XXXX      | × × × × × × × × × × × × × × × × × × ×             | b15 to b8<br>b31 to b24   | × × × × × × × × × × × × × × × × × × ×             | b7 to b0 | b23 to b16 | XXXX       |
| CPU                     | Address      | 2n + 0                                                  | 2n + 0   | 2n + 1                | 2n + 1                                                  | 2n + 0<br>2n + 1      | 2n + 0    | 2n + 1<br>2n + 2      | 2n + 1                     | 2n + 2    | 2n + 0<br>2n + 1<br>2n + 2<br>2n + 3              | 2n + 0<br>2n + 2          | 2n + 1<br>2n + 2<br>2n + 3<br>2n + 4              | 2n + 1   | 2n + 2     | 2n + 4     |
| Memory<br>Data Bus      |              | 8 bits 8 bits 16 bits 16 bits 16 bits                   |          | 8 bits 16 bits 8 bits |                                                         | 16 bits<br>8 bits     |           | 16 bits<br>8 bits     |                            | 16 bits   |                                                   |                           |                                                   |          |            |            |
| Operand                 | Address      | 2n + 0<br>(Even<br>number)<br>2n + 1<br>(Odd<br>number) |          | number)               | 2n + 0<br>(Even<br>number)<br>2n + 1<br>(Odd<br>number) |                       |           |                       | 2n + 0<br>(Even<br>number) |           |                                                   | 2n + 1<br>(Odd<br>number) |                                                   |          |            |            |
| Operand<br>Data         | Bus<br>Width | 8 bits                                                  |          |                       | 16 bits                                                 |                       |           |                       |                            | 32 bits   |                                                   |                           |                                                   |          |            |            |

xxxx: Indicates that the input data from these bits are ignored during a read. During a write, indicates that the bus for these bits goes to high impedance; also, that the write strobe signal for the bus remains inactive.

#### (3) Wait control

Bits 0 to 2 (<B0W0:2>, <B1W0:2>, <B2W0:2>, <B3W0:2>, <BEXW0:2>) of a chip select/wait control register specify the number of waits that are to be inserted when the corresponding memory area is accessed.

The following types of wait operation can be specified using these bits. Bit settings other than those listed in the table should not be made.

| <bxw2:0></bxw2:0> | Number of<br>Waits | Wait Operation                                                                                                                                                                                                   |
|-------------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 000               | 2 waits            | Inserts a wait of 2 states, irrespective of the WAIT pin state.                                                                                                                                                  |
| 001               | 1 wait             | Inserts a wait of 1 state, irrespective of the WAIT pin state.                                                                                                                                                   |
| 010               | (1 + N) waits      | Samples the state of the $\overline{\text{WAIT}}$ pin after inserting a wait of one state. If the $\overline{\text{WAIT}}$ pin is low, the waits continue and the bus cycle is extended until the pin goes high. |
| 011               | 0 waits            | Ends the bus cycle without a wait, regardless of the WAIT pin state.                                                                                                                                             |
| 100               | Reserved           | Invalid setting                                                                                                                                                                                                  |
| 101               | 3 waits            | Inserts a wait of 3 states, irrespective of the WAIT pin state.                                                                                                                                                  |
| 110               | 4 waits            | Inserts a wait of 4 states, irrespective of the WAIT pin state.                                                                                                                                                  |
| 111               | 8 waits            | Inserts a wait of 8 states, irrespective of the WAIT pin state.                                                                                                                                                  |

Table 3.6.3 Wait Operation Settings

A reset sets these bits to 000 (2 waits).

#### (4) Bus width and wait control for an area other than CS0 to CS3

The chip select/wait control register BEXCS controls the bus width and number of waits when memory locations, which are not in one of the four users specified address areas (CS0 to CS3), are accessed. The BEXCS register settings are always enabled for areas other than CS0 to CS3.

#### (5) Selecting 16-Mbyte area/specified address area

Setting B2CS<B2M> (Bit6 of the chip select/wait control register for CS2) to 0 designates the 16-Mbyte area (000FE0H to 000FFFH, 003000H to FF7FFFH) as the CS2 area. Setting B2CS<B2M> to 1 designates the address area specified by the start address register MSAR2 and the address mask register MAMR2 as CS2 (e.g., if B2CS<B2M>=1, CS2 is specified in the same manner as CS0, CS1 and CS3 are).

A reset clears this bit to 0, specifying CS2 as 16-Mbyte address area.

## (6) Procedure for setting chip select/wait control

When using the chip select/wait control function, set the registers in the following order:

a. Set the memory start address registers MSAR0 to MSAR3.

Set the start addresses for CS0 to CS3.

b. Set the memory address mask registers MAMR0 to MAMR3.

Set the sizes of CS0 to CS3.

c. Set the chip select/wait control registers B0CS to B3CS.

Set the chip select output waveform, data bus width, number of waits and master enable/disable status for  $\overline{\text{CS0}}$  to  $\overline{\text{CS3}}$ .

The CS0 to S3 pins can also function as pins P60 to P63. To output a chip select signal using one of these pins, set the corresponding bit in the port 6 function register (P6FC) to 1.

If a CS0 to S3 address is specified which is actually an internal I/O and RAM area address, the CPU accesses the internal address area and no chip select signal is output on any of the  $\overline{\text{CS0}}$  to  $\overline{\text{CS3}}$  pins.

## Example:

In this example CS0 is set to be the 64-Kbyte area 010000H to 01FFFFH. The bus width is set to 16 bits and the number of waits is set to 0.

MSAR0 = 01H ....... Start address: 010000H MAMR0 = 07H ..... Address area: 64 Kbytes BOCS = 83H ..... ROM/SRAM, 16-bit data bus, 0 waits, CS0 area settings enabled

## 3.6.3 Connecting External Memory

Figure 3.6.6 shows an example of how to connect external memory to the TMP91C820A. In this example the ROM is connected using a 16-bit bus. The RAM and I/O are connected using an 8-bit bus.



Figure 3.6.6 Example of External Memory Connection (ROM uses 16-bit bus; RAM and I/O use 8-bit bus.)

A reset clears all bits of the port 6 control register (P6CR) and the port 6 function register (P6FC) to 0 and disables output of the CS signal. To output the CS signal, the appropriate bit must be set to 1.



Figure 3.6.7 How to Connect to 16-Bit SRAM for TMP91C820A

# 3.7 8-Bit Timers (TMRA)

The TMP91C820A features 4 built-in 8-bit timers.

These timers are paired into four modules: TMRA01 and TMRA23. Each module consists of two channels and can operate in any of the following four operating modes.

- 8-bit interval timer mode
- 16-bit interval timer mode
- 8-bit programmable square wave pulse generation output mode (PPG: Variable duty cycle with variable period)
- 8-bit pulse width modulation output mode (PWM: Variable duty cycle with constant period)

Figure 3.7.1 and 3.7.2 show block diagrams for TMRA01 and TMRA23.

Each channel consists of an 8-bit up counter, an 8-bit comparator and an 8-bit timer register. In addition, a timer flip-flop and a prescaler are provided for each pair of channels.

The operation mode and timer flip-flops are controlled by five controls SFRs (Special function registers).

Each of the two modules (TMRA01 and TMRA23) can be operated independently. All modules operate in the same manner; hence only the operation of TMRA01 is explained here.

The contents of this chapter are as follows.

- 3.7.1 Block Diagrams
- 3.7.2 Operation of Each Circuit
- 3.7.3 SFRs
- 3.7.4 Operation in Each Mode
  - (1) 8-bit timer mode
  - (2) 16-bit timer mode
  - (3) 8-bit PPG (Programmable pulse generation) output mode
  - (4) 8-bit PWM (Pulse width modulation) output mode
  - (5) Settings for each mode
  - (6) LCDC and MELODY/ALARM circuit supply mode

Table 3.7.1 Registers and Pins for Each Module

|           | Module                           | TMRA01                           | TMRA23                           |
|-----------|----------------------------------|----------------------------------|----------------------------------|
| External  | Input pin for external clock     | TA0IN<br>(Shared with PB0)       | No                               |
| pin       | Output pin for timer flip-flop   | TA1OUT<br>(Shared with PB1)      | TA3OUT<br>(Shared with PB5)      |
|           | Timer run register               | TA01RUN (0100H)                  | TA23RUN (0108H)                  |
| SFR       | Timer register                   | TA0REG (0102H)<br>TA1REG (0103H) | TA2REG (010AH)<br>TA3REG (010BH) |
| (Address) | Timer mode register              | TA01MOD (0104H)                  | TA23MOD (010CH)                  |
|           | Timer flip-flop control register | TA1FFCR (0105H)                  | TA3FFCR (010DH)                  |

# 3.7.1 Block Diagrams



Figure 3.7.1 TMRA01 Block Diagram



Figure 3.7.2 TMRA23 Block Diagram

### 3.7.2 Operation of Each Circuit

#### (1) Prescaler

A 9-bit prescaler generates the input clock to TMRA01.

The clock  $\phi$ T0 is divided by 4 and input to this prescaler.  $\phi$ T0 can be either f<sub>FPH</sub> or fc/16 and is selected using the prescaler clock selection register SYSCR0<PRCK1:0>.

The prescaler operation can be controlled using TA01RUN<TA01PRUN> in the timer control register. Setting <TA01PRUN> to 1 starts the count; setting <TA01PRUN> to 0 clears the prescaler to 0 and stops operation. Table 3.7.2 shows the various prescaler output clock resolutions.

Table 3.7.2 Prescaler Output Clock Resolution

at fc = 36 MHz, fs = 32.768 kHz

| System                                | Prescaler Clock                  |                                   | Prescaler Output Clock Resolution |                              |                               |                                |  |  |  |
|---------------------------------------|----------------------------------|-----------------------------------|-----------------------------------|------------------------------|-------------------------------|--------------------------------|--|--|--|
| Clock<br>Selection<br><sysck></sysck> | Selection<br><prck1:0></prck1:0> | Gear Value<br><gear2:0></gear2:0> | φΤ1                               | φΤ4                          | φT16                          | фТ256                          |  |  |  |
| 1 (fs)                                |                                  | XXX                               | 2 <sup>3</sup> /fs (244 μs)       | 2 <sup>5</sup> /fs (977 μs)  | 2 <sup>7</sup> /fs (3.9 ms)   | 2 <sup>11</sup> /fs (62.5 ms)  |  |  |  |
|                                       |                                  | 000 (fc)                          | 2 <sup>3</sup> /fc (0.2 μs)       | 2 <sup>5</sup> /fc (0.9 μs)  | 2 <sup>7</sup> /fc (3.6 μs)   | 2 <sup>11</sup> /fc (56.9 μs)  |  |  |  |
|                                       | 00                               | 001 (fc/2)                        | 2 <sup>4</sup> /fc (0.4 μs)       | 2 <sup>6</sup> /fc (1.8 μs)  | 2 <sup>8</sup> /fc (7.1 μs)   | 2 <sup>12</sup> /fc (113.8 μs) |  |  |  |
|                                       | (f <sub>FPH</sub> )              | 010 (fc/4)                        | 2 <sup>5</sup> /fc (0.9 μs)       | 2 <sup>7</sup> /fc (3.6 μs)  | 2 <sup>9</sup> /fc (14.2 μs)  | 2 <sup>13</sup> /fc (227.6 μs) |  |  |  |
| 0 (fc)                                |                                  | 011 (fc/8)                        | 2 <sup>6</sup> /fc (1.8 μs)       | 2 <sup>8</sup> /fc (7.1 μs)  | 2 <sup>10</sup> /fc (28.4 μs) | 2 <sup>14</sup> /fc (455.1 μs) |  |  |  |
|                                       |                                  | 100 (fc/16)                       | 2 <sup>7</sup> /fc (3.6 μs)       | 2 <sup>9</sup> /fc (14.2 μs) | 2 <sup>11</sup> /fc (56.9 μs) | 2 <sup>15</sup> /fc (910.2 μs) |  |  |  |
|                                       | 10<br>(fc/16 CLOCK)              | XXX                               | 2 <sup>7</sup> /fc (3.6 μs)       | 2 <sup>9</sup> /fc (14.2 μs) | 2 <sup>11</sup> /fc (56.9 μs) | 2 <sup>15</sup> /fc (910.2 μs) |  |  |  |

xxx: Don't care

#### (2) Up counters (UC0 and UC1)

These are 8-bit binary counters which count up the input clock pulses for the clock specified by TA01MOD.

The input clock for UC0 is selectable and can be either the external clock input via the TA0IN pin or one of the three internal clocks  $\phi$ T1,  $\phi$ T4 or  $\phi$ T16. The clock setting is specified by the value set in TA01MOD<TA0CLK1:0><TA1CLK1:0>.

The input clock for UC1 depends on the operation mode. In 16-bit timer mode, the overflow output from UC0 is used as the input clock. In any mode other than 16-bit timer mode, the input clock is selectable and can either be one of the internal clocks  $\phi$ T1,  $\phi$ T16 or  $\phi$ T256, or the comparator output (The match detection signal) from TMRA0.

For each interval timer the timer operation control register bits TA01RUN <TA0RUN> and TA01RUN<TA1RUN> can be used to stop and clear the up counters and to control their count. A reset clears both up counters, stopping the timers.

#### (3) Timer registers (TA0REG and TA1REG)

These are 8-bit registers, which can be used to set a time interval. When the value set in the timer register TA0REG or TA1REG matches the value in the corresponding up counter, the comparator match detect signal goes active. If the value set in the timer register is 00H, the signal goes active when the up counter overflows.

The TAOREG are double buffer structure, each of which makes a pair with register buffer.

The setting of the bit TA01RUN<TA0RDE> determines whether TA0REG's double buffer structure is enabled or disabled. It is disabled if  $\langle TA0RDE \rangle = 0$  and enabled if  $\langle TA0RDE \rangle = 1$ .

When the double buffer is enabled, data is transferred from the register buffer to the timer register when a 2<sup>n</sup> overflow occurs in PWM mode, or at the start of the PPG cycle in PPG mode. Hence the double buffer cannot be used in timer mode.

A reset initializes <TA0RDE> to 0, disabling the double buffer. To use the double buffer, write data to the timer register, set <TA0RDE> to 1, and write the following data to the register buffer. Figure 3.7.3 shows the configuration of TA0REG.



Figure 3.7.3 Configuration of TA0REG

Note: The same memory address is allocated to the timer register and the register buffer. When <TA0RDE> = 0, the same value is written to the register buffer and the timer register; when <TA0RDE> = 1, only the register buffer is written to.

The address of each timer register is as follows.

TA0REG: 000102H TA1REG: 000103H TA2REG: 00010AH TA3REG: 00010BH

All these registers are write only and cannot be read.

## (4) Comparator (CP0)

The comparator compares the value in an up counter with the value set in a timer register. If they match, the up counter is cleared to 0 and an interrupt signal (INTTA0 or INTTA1) is generated. If timer flip-flop inversion is enabled, the timer flip-flop is inverted at the same time.

# (5) Timer flip-flop (TA1FF)

The timer flip-flop (TA1FF) is a flip-flop inverted by the match detects signal (8-bit comparator output) of each interval timer.

Whether inversion is enabled or disabled is determined by the setting of the bit TA1FFCR<TA1FFIE> in the timer flip-flops control register. A reset clears the value of TA1FF to 0. Writing 01 or 10 to TA1FFCR<TA1FFC1:0> sets TA1FF to 0 or 1. Writing 00 to these bits inverts the value of TA1FF. (This is known as software inversion.)

The TA1FF signal is output via the TA1OUT pin. When this pin is used as the timer output, the timer flip-flop should be set beforehand using the port B function register PBCR, PBFC.

Note: When the double buffer is enabled for an 8-bit timer in PWM or PPG mode, caution is required as explained below.

If new data is written to the register buffer immediately before an overflow occurs by a match between the timer register value and the up-counter value, the timer flip-flop may output an unexpected value.

For this reason, make sure that in PWM mode new data is written to the register buffer by six cycles ( $f_{SYS} \times 6$ ) before the next overflow occurs by using an overflow interrupt. In the case of using PPG mode, make sure that new data is written to the register buffer by six cycles before the next cycle compare match occurs by using a cycle compare match interrupt.

### Example when using PWM mode



# 3.7.3 SFRs

TMRA01 Run Register



I2TA01: Operation in IDLE2 mode

TA01PRUN: Run prescaler TA1RUN: Run TMRA1 TA0RUN: Run TMRA0

Note: The values of bits 4 to 6 of TA01RUN are undefined when read.

TMRA23 Run Register

|         |             | 7             | 6                | 5      | 4 | 3          | 2             | 1           | 0              |
|---------|-------------|---------------|------------------|--------|---|------------|---------------|-------------|----------------|
| TA23RUN | Bit symbol  | TA2RDE        |                  |        |   | I2TA23     | TA23PRUN      | TA3RUN      | TA2RUN         |
| (0108H) | Read/Write  | R/W           |                  |        |   |            | R/            | W           |                |
|         | After reset | 0             |                  |        |   | 0          | 0             | 0           | 0              |
|         | Function    | Double        |                  |        |   | IDLE2      | 8-bit timer r | un/stop con | trol           |
|         |             | buffer        |                  |        |   | 0: Stop    | 0: Stop and   | clear       |                |
|         |             | 0: Disable    | е                |        |   | 1: Operate | 1: Run (Cou   | ınt up)     |                |
|         |             | 1: Enable     | )                |        |   |            |               |             |                |
|         |             | ↓<br>TA2REG o | double buffer co | ontrol |   |            |               | → Timer rui | n/stop control |
|         |             | 0 Di          | sable            |        |   |            |               | 0 \$        | Stop and clear |
|         |             | 1 Eı          | nable            |        |   |            |               | 1 1         | Run (Count up) |

I2TA23: Operation in IDLE2 mode

TA23PRUN: Run prescaler TA3RUN: Run TMRA3 TA2RUN: Run TMRA2

Note: The values of bits 4 to 6 of TA23RUN are undefined when read.

Figure 3.7.4 Register for TMRA



Figure 3.7.5 Register for TMRA



Figure 3.7.6 Register for TMRA



Figure 3.7.7 Register for TMRA



Figure 3.7.8 Register for TMRA

# TMRA register

|         |             | 7 | 6         | 5 | 4    | 3      | 2 | 1 | 0 |  |  |  |  |  |
|---------|-------------|---|-----------|---|------|--------|---|---|---|--|--|--|--|--|
| TA0REG  | bit Symbol  | - |           |   |      |        |   |   |   |  |  |  |  |  |
| (0102H) | Read/Write  |   |           |   |      |        |   |   |   |  |  |  |  |  |
|         | After reset |   |           |   | Unde | efined |   |   |   |  |  |  |  |  |
| TA1REG  | bit Symbol  |   |           |   | -    | -      |   |   |   |  |  |  |  |  |
| (0103H) | Read/Write  |   | W         |   |      |        |   |   |   |  |  |  |  |  |
|         | After reset |   | Undefined |   |      |        |   |   |   |  |  |  |  |  |
| TA2REG  | bit Symbol  |   | -         |   |      |        |   |   |   |  |  |  |  |  |
| (010AH) | Read/Write  |   | W         |   |      |        |   |   |   |  |  |  |  |  |
|         | After reset |   | Undefined |   |      |        |   |   |   |  |  |  |  |  |
| TA3REG  | bit Symbol  |   |           |   | -    | =      |   |   |   |  |  |  |  |  |
| (010BH) | Read/Write  |   |           |   | V    | V      |   |   |   |  |  |  |  |  |
|         | After reset |   |           | • | Unde | efined |   | • |   |  |  |  |  |  |

Note: The above registers are prohibited read-modify-write instruction.

Figure 3.7.9 Register for TMRA

# 3.7.4 Operation in Each Mode

(1) 8-bit timer mode

Both TMRA0 and TMRA1 can be used independently as 8-bit interval timers.

a. Generating interrupts at a fixed interval (Using TMRA1)

To generate interrupts at constant intervals using TMRA1 (INTTA1), first stop TMRA1 then set the operation mode, input clock and a cycle to TA01MOD and TA1REG register respectively. Then, enable the interrupt INTTA1 and start TMRA1 counting.

Example: To generate an INTTA1 interrupt every 8.0  $\underline{\mu}$ s at fc = 36 MHz, set each register as follows:

|          | MSE | 3 |   |   |   |   | LSE | 3 |   |                                                                                               |
|----------|-----|---|---|---|---|---|-----|---|---|-----------------------------------------------------------------------------------------------|
|          |     | 7 | 6 | 5 | 4 | 3 | 2   | 1 | 0 |                                                                                               |
| TA01RUN  | ← · | _ | _ | Χ | Χ | _ | _   | 0 | _ | Stop TMRA1 and clear it to 0.                                                                 |
| TA01MOD  | ← ( | 0 | 0 | Χ | Χ | 1 | 0   | - | - | Select 8-bit timer mode and select $\phi T1$ (0.2 $\mu s$ at fc = 36 MHz) as the input clock. |
| TA1REG   | ← ( | 0 | 0 | 1 | 0 | 1 | 0   | 0 | 0 | Set TA1REG to 8.0 $\mu$ s ÷ $\phi$ T1 = 40 = 28H.                                             |
| INTETA01 | ← 2 | Χ | 1 | 0 | 1 | - | -   | _ | _ | Enable INTTA1 and set it to level 5.                                                          |
| TA01RUN  | ← · | _ | Χ | Χ | Χ | - | 1   | 1 | - | Start TMRA1 counting.                                                                         |

X: Don't care, -: No change

Select the input clock using Table 3.7.2.

Note: The input clocks for TMRA0 and TMRA1 are different from as follows.

TMRA0: TA0IN input,  $\phi$ T1,  $\phi$ T4 or  $\phi$ T16.

TMRA1: Match output of TMRA0, φT1, φT16, φT256.

b. Generating a 50% duty ratio square wave pulse

The state of the timer flip-flop (TA1FF) is inverted at constant intervals and its status output via the timer output pin (TA1OUT).

Example: To output a 1.2  $\mu$ s square wave pulse from the TA1OUT pin at fc = 36MHz, use the following procedure to make the appropriate register settings. This example uses TMRA1; however, either TMRA0 or TMRA1 may be used.



X: Don't care, -: No change



Figure 3.7.10 Square Wave Output Timing Chart (50% duty)

c. Making TMRA1 count up on the match signal from the TMRA0 comparator Select 8-bit timer mode and set the comparator output from TMRA0 to be the input clock to TMRA1.



Figure 3.7.11 TMRA1 Count Up on Signal from TMRA0

#### (2) 16-bit timer mode

Pairing the two 8-bit timers TMRA0 and TMRA1 configures a 16-bit interval timer. To make a 16-bit interval timer in which TMRA0 and TMRA1 are cascaded together, set TA01MOD<TA01M1:0> to 01.

In 16-bit timer mode, the overflow output from TMRA0 is used as the input clock for TMRA1, regardless of the value set in TA01MOD<TA01CLK1:0>. Table 3.7.2 shows the relationship between the timer (Interrupt) cycle and the input clock selection.

Setting example: To generate an INTTA1 interrupt every 0.22 s at fc = 36 MHz, set the timer registers TA0REG and TA1REG as follows:

\* Clock state

System clock: High frequency (fc)

Clock gear: 1 (fc)

Prescaler clock: f<sub>PH</sub>

If  $\phi$ T16 ((2<sup>7</sup>/fc)s at 36 MHz) is used as the input clock for counting, set the following value in the registers:

 $0.22 \text{ s} \div (2^7/\text{fc})\text{s} \approx 62500 = \text{F424H}$ 

(e.g. set TA1REG to F4H and TA0REG to 24H).

As a result, INTTA1 interrupt can be generated every 0.23 [s].

The comparator match signal is output from TMRA0 each time the up counter UC0 matches TA0REG, though the up counter UC0 is not be cleared.

In the case of the TMRA1 comparator, the match detect signal is output on each comparator pulse on which the values in the up counter UC1 and TA1REG match. When the match detect signal is output simultaneously from both the comparator TMRA0 and TMRA1, the up counters UC0 and UC1 are cleared to 0 and the interrupt INTTA1 is generated. Also, if inversion is enabled, the value of the timer flip-flop TA1FF is inverted.

Example: When TA1REG = 04H and TA0REG = 80H



Figure 3.7.12 Timer Output by 16-Bit Timer Mode

# (3) 8-bit PPG (Programmable pulse generation) output mode

Square wave pulses can be generated at any frequency and duty ratio by TMRA0. The output pulses may be active-low or active-high. In this mode TMRA1 cannot be used.

TMRA0 outputs pulses on the TA1OUT pin.



Example when <TA1FFC1:0>="01"



Figure 3.7.13 8-Bit PPG Output Waveforms

In this mode a programmable square wave is generated by inverting the timer output each time the 8-bit up counter (UCO) matches the value in one of the timer registers TA0REG or TA1REG.

The value set in TAOREG must be smaller than the value set in TA1REG.

Although the up counter for TMRA1 (UC1) is not used in this mode, TA01RUN<TA1RUN> should be set to 1 so that UC1 is set for counting.

Figure 3.7.14 shows a block diagram representing this mode.



Figure 3.7.14 Block Diagram of 8-Bit PPG Output Mode

If the TAOREG double buffer is enabled in this mode, the value of the register buffer will be shifted into TAOREG each time TA1REG matches UCO.

Use of the double buffer facilitates the handling of low-duty waves (when duty is varied).



Figure 3.7.15 Operation of Register Buffer

Example: To generate 1/4 duty 50 kHz pulses (at fc = 36 MHz):



Calculate the value, which should be set in the timer register.

To obtain a frequency of 50 kHz, the pulse cycle t should be: t = 1/50 kHz = 20  $\mu$ s  $\phi$ T1 = (2 $^3$ /fc)s (at 36 MHz);

$$20 \ \mu s \div (2^3/fc)s \approx 90$$

Therefore set TA1REG to 90 (5AH)

The duty is to be set to 1/4:  $t \times 1/4 = 20 \mu s \times 1/4 = 5 \mu s$ 

$$5 \, \mu s \div (2^3/fc)s \approx 22$$

Therefore, set TAOREG = 22 = 16H.



X: Don't care, -: No change

# (4) 8-bit PWM (Pulse width modulation) output mode

This mode is only valid for TMRA0. In this mode, a PWM pulse with the maximum resolution of 8 bits can be output.

When TMRA0 is used the PWM pulse is output on the TA1OUT pin. TMRA1 can also be used as an 8-bit timer.

The timer output is inverted when the up counter (UC0) matches the value set in the timer register TA0REG or when  $2^n$  counter overflow occurs (n = 6, 7 or 8 as specified by TA01MOD<PWM01:00>). The up counter UC0 is cleared when  $2^n$  counter overflow occurs.

The following conditions must be satisfied before this PWM mode can be used.

Value set in TA0REG < Value set for  $2^n$  counter overflow Value set in TA0REG  $\neq 0$ 



Figure 3.7.16 8-Bit PWM Waveforms

Figure 3.7.17 shows a block diagram representing this mode.



Figure 3.7.17 Block Diagram of 8-Bit PWM Mode

In this mode the value of the register buffer will be shifted into TAOREG if 2<sup>n</sup> overflow is detected when the TAOREG double buffer is enabled.

Use of the double buffer facilitates the handling of low duty ratio waves.



Figure 3.7.18 Register Buffer Operation

Example: To output the following PWM waves on the TA1OUT pin at fc = 36 MHz:



To achieve a 28.4  $\mu$ s PWM cycle by setting  $\phi$ T1 to (2 $^3$ /fc)s (at fc = 36 MHz):

$$28.4~\mu s \div (2^3/fc)s \approx 128 = 2^n$$

Therefore n should be set to 7.

X: Don't care, -: No change

Since the low-level period is 16.0  $\mu s$  when  $\phi T1$  = 0.5  $\mu s,$ 

set the following value for TAOREG:

$$16.0 \ \mu s \div (2^3/fc)s \approx 72 = 48H$$

|              | MSB        |   |        |        |   |        | L      | SB     |   |                                                                                |
|--------------|------------|---|--------|--------|---|--------|--------|--------|---|--------------------------------------------------------------------------------|
| _            | 7          | 6 | 5      | 4      | 3 | 2      | 1      | 0      |   |                                                                                |
| TA01RUN      | ← -        | Χ | Χ      | Χ      | _ | _      | _      | 0      |   | Stop TMRA0 and clear it to 0.                                                  |
| TA01MOD      | ← 1        | 1 | 1      | 0      | - | -      | 0      | 1      |   | Select 8-bit PWM mode (cycle: $2^7$ ) and select $\phi T1$ as the input clock. |
| TA0REG       | ← 0        | 1 | 0      | 0      | 1 | 0      | 0      | 0      |   | Write 48H.                                                                     |
| TA1FFCR      | ← X        | Χ | Χ      | Χ      | 1 | 0      | 1      | Χ      |   | Clear TA1FF to 0; enable the inversion and double buffer.                      |
| PBCR<br>PBFC | ← X<br>← X | - | _<br>_ | -<br>- | _ | X<br>X | 1<br>1 | -<br>- | } | Set PB1 and the TA1OUT pin.                                                    |
| TA01RUN      | ← 1        | Χ | Χ      | Χ      | - | 1      | -      | 1      |   | Start TMRA0 counting.                                                          |

Table 3.7.3 PWM Cycle

at fc = 36 MHz, fs = 32.768 kHz

| Select                   | Select                       | Gear value  |         | PWM cycle      |         |         |                |               |         |                |               |         |         |
|--------------------------|------------------------------|-------------|---------|----------------|---------|---------|----------------|---------------|---------|----------------|---------------|---------|---------|
| system                   | prescaler                    |             |         | 2 <sup>6</sup> |         |         | 2 <sup>7</sup> |               |         | 2 <sup>8</sup> |               |         |         |
| clock<br><sysck></sysck> | clock<br><prck1:0></prck1:0> | VOLANZ.07   | φT1     | φТ4            | φT16    | φT1     | φΤ4            | φ <b>T</b> 16 | φΤ1     | φΤ4            | φ <b>T</b> 16 |         |         |
| 1 (fs)                   |                              | XXX         | 15.6 ms | 62.5 ms        | 250 ms  | 31.3 ms | 125 ms         | 500 ms        | 62.5 ms | 250 ms         | 1000 ms       |         |         |
|                          | 00<br>(f <sub>FPH</sub> )    | 000 (fc)    | 14.2 μs | 56.8 μs        | 227 μs  | 28.4 μs | 113µs          | 455 μs        | 56.8 μs | 227 μs         | 910 μs        |         |         |
|                          |                              | 001 (fc/2)  | 28.4 μs | 113 μs         | 455 μs  | 56.8 μs | 227 μs         | 910 μs        | 113 μs  | 455 μs         | 1820 μs       |         |         |
|                          |                              | 010 (fc/4)  | 56.8 μs | 227 μs         | 910 μs  | 113 μs  | 455 μs         | 1820 μs       | 227 μs  | 910 μs         | 3640 μs       |         |         |
| 0 (fc)                   |                              |             |         | 011 (fc/8)     | 113 μs  | 455 μs  | 1820 μs        | 227 μs        | 910 μs  | 3640 μs        | 455 μs        | 1820 μs | 7281 μs |
| 0 (10)                   |                              | 100 (fc/16) | 227 μs  | 910 μs         | 3640 μs | 455 μs  | 1820 μs        | 7281 μs       | 910 μs  | 3640 μs        | 14563 μs      |         |         |
|                          | 10<br>(fc/16<br>Clock)       | XXX         | 227 μs  | 910 μs         | 3640 μs | 455 μs  | 1820 μs        | 7281 μs       | 910 μs  | 3640 μs        | 14563 μs      |         |         |

XXX: Don't care

# (5) Settings for each mode

Table 3.7.4 shows the SFR settings for each mode.

Table 3.7.4 Timer Mode Setting Registers

| Register Name            |                       | TA01                                                          | MOD                                                 |                                                                           | TA1FFCR                                        |
|--------------------------|-----------------------|---------------------------------------------------------------|-----------------------------------------------------|---------------------------------------------------------------------------|------------------------------------------------|
| <bit symbol=""></bit>    | <ta01m1:0></ta01m1:0> | <pwm01:00></pwm01:00>                                         | <ta1clk1:0></ta1clk1:0>                             | <ta0clk1:0></ta0clk1:0>                                                   | TA1FFIS                                        |
| Function                 | Timer Mode            | PWM Cycle                                                     | Upper Timer Input<br>Clock                          | Lower Timer<br>Input Clock                                                | Timer F/F Invert Signal<br>Select              |
| 8-bit timer × 2 channels | 00                    | -                                                             | Lower timer match φT1, φT16, φT256 (00, 01, 10, 11) | External clock<br>\$\phi\$T1, \$\phi\$T4, \$\phi\$T16<br>(00, 01, 10, 11) | 0: Lower timer output<br>1: Upper timer output |
| 16-bit timer mode        | 01                    | -                                                             | -                                                   | External clock<br>\$\phi T1, \$\phi T4, \$\phi T16\$<br>(00, 01, 10, 11)  | -                                              |
| 8-bit PPG × 1 channel    | 10                    | -                                                             | -                                                   | External clock<br>\$\phi T1, \$\phi T4, \$\phi T16\$<br>(00, 01, 10, 11)  | -                                              |
| 8-bit PWM × 1 channel    | 11                    | 2 <sup>6</sup> , 2 <sup>7</sup> , 2 <sup>8</sup> (01, 10, 11) | -                                                   | External clock<br>\$\phi T1, \$\phi T4, \$\phi T16\$<br>(00, 01, 10, 11)  | -                                              |
| 8-bit timer × 1 channel  | 11                    | _                                                             | φT1, φT16, φT256<br>(01, 10, 11)                    | -                                                                         | Output disabled                                |

<sup>-:</sup> Don't care

# (6) LCDC and MELODY/ALARM circuit supply mode

This function can operate only TMRA3. It can use LCDC or MELODY/ALARM source clock TA3 clock generated by TMRA3. And keep the rule under below.

#### **OPERATE**

- 1. Clock generate by timer 3
- 2. Clock supply start ( $\langle TA3LCDE \rangle = 1$  or  $\langle TA3MLD \rangle = 1$ )
- 3. Need setup time
- 4. LCDC or MELODY/ALARM start to operate

# STOP

- 1. LCDC or MELODY/ALARM stop to operate
- 2. Clock supply cut off ( $\langle TA3LCDE \rangle = 0$  or  $\langle TA3MLDE \rangle = 0$ )

| EMCCR0  |
|---------|
| (00E3H) |
| . ,     |

|   |             | 7            | 6            | 5         | 4            | 3          | 2           | 1              | 0              |
|---|-------------|--------------|--------------|-----------|--------------|------------|-------------|----------------|----------------|
| 0 | Bit symbol  | PROTECT      | TA3LCDE      | AHOLD     | TA3MLDE      | HRESENA    | EXTIN       | DRVOSCH        | DRVOSCL        |
|   | Read/Write  | R            | R/W          | R/W       | R/W          | R/W        | R/W         | R/W            | R/W            |
|   | After reset | 0            | 0            | 0         | 0            | 0          | 0           | 1              | 1              |
|   | Function    | Protect flag | LCDC         | Address   | Melody/alarm | HRESET     | 1: External | fc oscillator  | fs oscillator  |
|   |             | 0: OFF       | source clock | hold      | source clock | 0: Disable | clock       | driver ability | driver ability |
|   |             | 1: ON        | 0: 32 kHz    | 0: Normal | 0: 32 kHz    | 1: Enable  |             | 1: Normal      | 1: Normal      |
|   |             |              | 1: TA3OUT    | 1: Enable | 1: TA3OUT    |            |             | 0: Weak        | 0: Weak        |

# 3.8 External Memory Extension Function (MMU)

This is MMU function which can expand program/data area to 136 Mbytes by having 4 local areas.

Address pins to external memory are 2 extended address bus pins (EA24, EA25) and 8 extended chip select pins ( $\overline{\text{CS2A}}$  to  $\overline{\text{CS2G}}$  and  $\overline{\text{CSEXA}}$ ) in addition to 24 address bus pins (A0 to A23) which are common specification of TLCS-900 family and 4 chip select pins ( $\overline{\text{CS0}}$  to  $\overline{\text{CS3}}$ ) output from CS/WAIT controller.

The feature and the recommendation setting method of two types are shown below. In addition, "AH" in the table is the value which number address 23 to 16 displayed as hex.

| Purpose                                            | ltem                            | Recommendation setting method                                                                                                                                   |  |  |  |  |
|----------------------------------------------------|---------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
|                                                    | Maximum memory size             | 16Mbytes (16 Mbytes × 1 pcs)                                                                                                                                    |  |  |  |  |
| Program ROM                                        | Used local area, BANK number    | LOCAL2 (AH = $C0 - DF$ : 2 Mbytes × 7 BANK)                                                                                                                     |  |  |  |  |
| 1 Togram Now                                       | Setting CS/WAIT                 | Setup AH = 80 - FF to CS2                                                                                                                                       |  |  |  |  |
|                                                    | Used CS pin                     | CS2A                                                                                                                                                            |  |  |  |  |
|                                                    | Maximum memory size             | 96 Mbytes (16 Mbytes × 6 pcs)                                                                                                                                   |  |  |  |  |
| Data ROM                                           | Used local area, BANK number    | LOCAL3 (AH = 80 – BF: 4 Mbytes × 24 BANK)                                                                                                                       |  |  |  |  |
| Data NOW                                           | Setting CS/WAIT                 | Setup AH = 80 - FF to CS2                                                                                                                                       |  |  |  |  |
|                                                    | Used CS pins                    | $\overline{\text{CS2B}}$ , $\overline{\text{CS2C}}$ , $\overline{\text{CS2D}}$ , $\overline{\text{CS2E}}$ , $\overline{\text{CS2F}}$ , $\overline{\text{CS2G}}$ |  |  |  |  |
|                                                    | Maximum memory size             | 16 Mbyte (16 Mbytes × 1 pcs)                                                                                                                                    |  |  |  |  |
| Option program ROM                                 | Used local area, BANK number    | LOCAL1 (AH = 40 – 5F: 2 Mbytes × 7 BANK)                                                                                                                        |  |  |  |  |
| Option program Kow                                 | Setting CS/WAIT                 | Setup AH = 40 – 7F to CS1                                                                                                                                       |  |  |  |  |
|                                                    | Used CS pin                     | <del>CS1</del>                                                                                                                                                  |  |  |  |  |
|                                                    | Maximum memory size             | 8 Mbytes (8 Mbytes × 1pcs)                                                                                                                                      |  |  |  |  |
| Data RAM                                           | Used local area, BANK number    | LOCAL0 (AH = $10 - 1F$ : 1 Mbyte $\times$ 7 BANK)                                                                                                               |  |  |  |  |
| Data NAIVI                                         | Setting CS/WAIT                 | Setup AH = 00 – 1F to CS3                                                                                                                                       |  |  |  |  |
|                                                    | Used CS pin                     | <del>CS3</del>                                                                                                                                                  |  |  |  |  |
|                                                    | Maximum memory size             | 1 Mbyte (1 Mbyte × 1 pcs)                                                                                                                                       |  |  |  |  |
| Extended memory 1                                  | Used local area, BANK number    | None                                                                                                                                                            |  |  |  |  |
| Extended memory 1                                  | Setting CS/WAIT                 | Setup AH = 20 – 2F to CS0                                                                                                                                       |  |  |  |  |
|                                                    | Used CS pin                     | <del>CS0</del>                                                                                                                                                  |  |  |  |  |
|                                                    | Maximum memory size             | 256 Kbytes (256 Kbytes × 1 pcs)                                                                                                                                 |  |  |  |  |
| Extended memory 2                                  | Used local area, BANK number    | None                                                                                                                                                            |  |  |  |  |
| Extended memory 2                                  | Setting CS/WAIT                 | Setup AH = $30 - 3F$ to $\overline{CSEX}$                                                                                                                       |  |  |  |  |
|                                                    | Used $\overline{\text{CS}}$ pin | CSEXA                                                                                                                                                           |  |  |  |  |
|                                                    | Maximum memory size             | 256 Kbytes (64 Kbytes × 4 pcs)                                                                                                                                  |  |  |  |  |
| Extended memory 3                                  | Used local area, BANK number    | None                                                                                                                                                            |  |  |  |  |
| (Direct address assigned built-in type LCD driver) | Setting CS/WAIT                 | Setup AH = 30 – 3F to CSEX                                                                                                                                      |  |  |  |  |
|                                                    | Used CS pin                     | D1BSCP, D2BLP, D3BFR, DLEBCD                                                                                                                                    |  |  |  |  |
|                                                    | Maximum memory size             | 512 Kbytes                                                                                                                                                      |  |  |  |  |
| Futandad maman: 4                                  | Used local area, BANK number    | ·                                                                                                                                                               |  |  |  |  |
| Extended memory 4                                  | Setting CS/WAIT                 | Setup AH = 30 – 3F to CSEX                                                                                                                                      |  |  |  |  |
|                                                    | Used CS pin                     | None                                                                                                                                                            |  |  |  |  |

Note: SDRAM must be mapped in LOCAL1 area. It can't use other area.

# 3.8.1 Recommendable Memory Map

The recommendation logic address memory map at the time of variety extension memory correspondence is shown in Figure 3.8.1. And, a physical-address map is shown in Figure 3.8.2.

However, when memory area is less than 16 Mbytes and is not expanded, please refer to section of CS/WAIT controller. Setting of register in MMU is not necessary.

The area which can be set as Bank is called local-area. While the area for managing the Bank is called common-area.

Since they are being fixed, the address of a common-area and a local-area cannot be changed.



Figure 3.8.1 Recommendation Address Map (Physical address)



Figure 3.8.2 Physical Address Map

# 3.8.2 Explanation of SFR

There are 4 registers; LOCAL0 to LOCAL3. Each register is for enabling bank and setting bank.

Setup LOCAL registers in common area. And, a combination pin and the CS/WAIT controller need to be set. When CPU outputs logical address of the LOCAL area, MMU outputs physical address to the outside address bus pin according to value of bank setting register. Access of external memory becomes possible therefore.

|          |                                                                                                                                                      |                                  |   | LOC           | AL0 Registe                               | r         |                                         |                                   |                |  |  |  |  |
|----------|------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------|---|---------------|-------------------------------------------|-----------|-----------------------------------------|-----------------------------------|----------------|--|--|--|--|
|          |                                                                                                                                                      | 7                                | 6 | 5             | 4                                         | 3         | 2                                       | 1                                 | 0              |  |  |  |  |
| LOCAL0   | Bit symbol                                                                                                                                           | L0E                              |   |               |                                           |           | L0EA22                                  | L0EA21                            | L0EA20         |  |  |  |  |
| (0350H)  | Read/Write                                                                                                                                           | R/W                              |   |               |                                           |           |                                         | R/W                               |                |  |  |  |  |
|          | After reset                                                                                                                                          | 0                                |   |               |                                           |           | 0                                       | 0                                 | 0              |  |  |  |  |
|          | Function                                                                                                                                             | BANK for LOCAL0                  |   |               |                                           |           | Setting BANK number for LOCALO          |                                   |                |  |  |  |  |
|          |                                                                                                                                                      | 0: Disable<br>1: Enable          |   |               |                                           |           |                                         | not set "000" because common area |                |  |  |  |  |
|          | LOCAL1 Register                                                                                                                                      |                                  |   |               |                                           |           |                                         |                                   |                |  |  |  |  |
|          |                                                                                                                                                      | 7                                | 6 | 5             | 4                                         | 3         | 2                                       | 1                                 | 0              |  |  |  |  |
| LOCAL1   | Bit symbol                                                                                                                                           | L1E                              |   |               |                                           |           | L1EA23                                  | L1EA22                            | L1EA21         |  |  |  |  |
| (0351H)  | Read/Write                                                                                                                                           | R/W                              |   |               |                                           |           |                                         | R/W                               |                |  |  |  |  |
|          | After reset                                                                                                                                          | 0                                |   |               |                                           |           | 0                                       | 0                                 | 0              |  |  |  |  |
|          | Function                                                                                                                                             | BANK for LOCAL1                  |   |               |                                           |           | Setting BANK number for LOCAL1          |                                   |                |  |  |  |  |
|          |                                                                                                                                                      | 0: Disable<br>1: Enable          |   |               |                                           |           | Do not set "001" because of common area |                                   |                |  |  |  |  |
|          |                                                                                                                                                      | 7                                | 6 | LOC<br>5      | AL2 Registe                               | r<br>3    | 2                                       | 1                                 | 0              |  |  |  |  |
| LOCAL2   | Dit ayımbal                                                                                                                                          | L2E                              |   |               | 4                                         |           | L2EA23                                  | -                                 | L2EA21         |  |  |  |  |
| (0352H)  | Bit symbol                                                                                                                                           |                                  |   | $\overline{}$ |                                           |           | LZEA23                                  | L2EA22                            | LZEAZI         |  |  |  |  |
| (000211) | Read/Write                                                                                                                                           | R/W                              |   | $\overline{}$ |                                           |           | 0                                       | R/W                               | 0              |  |  |  |  |
|          | After reset<br>Function                                                                                                                              | 0<br>BANK for<br>LOCAL2          |   |               |                                           |           | 0<br>Setting BA                         | 0<br>NK number f                  | 0<br>or LOCAL2 |  |  |  |  |
|          |                                                                                                                                                      | 0: Disable<br>1: Enable          |   |               |                                           |           |                                         | set "111" bed<br>common area      |                |  |  |  |  |
|          |                                                                                                                                                      |                                  |   | LOC           | AL3 Registe                               | r         |                                         |                                   |                |  |  |  |  |
|          |                                                                                                                                                      | 7                                | 6 | 5             | 4                                         | 3         | 2                                       | 1                                 | 0              |  |  |  |  |
| LOCAL3   | Bit symbol                                                                                                                                           | L3E                              |   |               | L3EA26                                    | L3EA25    | L3EA24                                  | L3EA23                            | L3EA22         |  |  |  |  |
| (0353H)  | Read/Write                                                                                                                                           | R/W                              |   |               | R/W                                       | R/W       | R/W                                     | R/W                               | R/W            |  |  |  |  |
|          | After reset                                                                                                                                          | 0                                |   |               | 0                                         | 0         | 0                                       | 0                                 | 0              |  |  |  |  |
|          | Function                                                                                                                                             | BANK for<br>LOCAL3<br>0: Disable |   |               | 01000 to 01<br>00000 to 00<br>00100 to 00 | 011: CS2B | 01100 to 0<br>10000 to 1<br>10100 to 1  |                                   |                |  |  |  |  |
|          | 0: Disable   00100 to 00111: \( \overline{\text{CS2C}} \) 10100 to 10111: \( \overline{\text{CS2G}} \)   1: Enable   11000 to 11111: Set prohibition |                                  |   |               |                                           |           |                                         |                                   |                |  |  |  |  |

Figure 3.8.3 Register for LOCAL0 to LOCAL3



Figure 3.8.4 H/W Setting Example

At Figure 3.8.4, it shows example of connection TMP91C820A and some memories: program ROM: MROM, 16 Mbyte, data ROM: MROM, 64 Mbyte, data RAM: SRAM, 8 Mbyte, 8-bit bus, display RAM: SDRAM, 16 Mbytes.

In case of 16-bit bus memory connection, it need to shift 1-bit address bus from TMP91C820A and 8-bit bus case, direct connection address bus from TMP91C820A.

In that figure, logical address and physical address are shown. And each memory allot each chip select signal, RAM:  $\overline{\text{CS0}}$ , SDRAM:  $\overline{\text{CS1}}$ , program MROM:  $\overline{\text{CS2}}$ , data MROM:  $\overline{\text{CS3}}$  in case of this example, as data MROM is 64 Mbyte, this MROM connect to EA24 and EA25.

Initial condition after reset, because TMP91C820A access from CS2 area, CS2 area allots to program ROM. It can set free setting except program ROM.

| ;Initial<br>;CS0 | Setting   |                            |                                                                     |
|------------------|-----------|----------------------------|---------------------------------------------------------------------|
| ,030             | LD        | (MSAR0),00H                | ; Logical address area: 000000H to 1FFFFFH                          |
|                  | LD        | (MAMR0),FFH                | ; Logical address size: 2 Mbytes                                    |
|                  | LD        | (B0CS),89H                 | ; Condition: 8 bits, 1 wait (8 Mbytes, SRAM)                        |
| ;CS1             |           |                            |                                                                     |
|                  | LD        | (MSAR1),40H                | ; Logical address area: 400000H to 5FFFFFH                          |
|                  | LD        | (MAMR1),FFH                | ; Logical address size: 4 Mbytes                                    |
|                  | LD        | (B1CS),83H                 | ; Condition: 16 bits, 0 waits (16 Mbytes, SDRAM)                    |
| ;CS2             |           |                            |                                                                     |
|                  | LD        | (MSAR2),C0H                | ; Logical address area: C00000H to FFFFFH                           |
|                  | LD        | (MAMR2),7FH                | ; Logical address size: 4 Mbytes                                    |
|                  | LD        | (B2CS),C3H                 | ; Condition: 16 bits, 0 waits (16 Mbytes, MROM)                     |
| ;CS3             |           |                            |                                                                     |
|                  | LD        | (MSAR3),80H                | ; Logical address area: 800000H to BFFFFFH                          |
|                  | LD        | (MAMR3),7FH                | ; Logical address size: 4 Mbytes                                    |
|                  | LD        | (B3CS),85H                 | ; Condition: 16 bits, 3 waits (64 Mbytes, MROM)                     |
| ;CSX             |           |                            |                                                                     |
|                  | LD        | (BEXCS),00H                | ; Other: 16 bits, 2 waits (Don't care)                              |
| ;Port            |           |                            |                                                                     |
|                  | LD        | (P6FC),3FH                 | ; $\overline{CS0}$ to $\overline{CS3}$ , EA24, EA25: port 6 setting |
|                  | LD        | (P6FC2),02H                | $; \overline{CS1} \rightarrow \overline{SDCS}$ setting              |
| to               | 1.0\\\    | (DZOD) 070711              | ; HWR , WR , RD                                                     |
|                  | LDW<br>LD | (PZCR),0707H<br>(PFFC),7FH | ; PF [6:0] = SDRAM control                                          |
|                  | LD        | (SDACR),0ADH               | ; Add-MUX enable, 128-M select                                      |
|                  |           |                            |                                                                     |
| to               |           |                            | ; SDRAM setup time                                                  |
|                  | LD        | (SDACR),06DH               | ; Add MUX enable, 128-M select                                      |
|                  | LD        | (SDRCR),01H                | ; Interval reflesh                                                  |

Figure 3.8.5 Bank Operation S/W Example 1

Secondly, it shows example of initial setting at Figure 3.8.5.

Because  $\overline{\text{CS0}}$  connect to RAM: 8-bit bus, 8 Mbytes, it need to set 8-bit bus. At this example, it set 1-wait setting. In the same way  $\overline{\text{CS1}}$  set to 16-bit bus and 0 waits,  $\overline{\text{CS2}}$  set 16-bit bus and 0 waits,  $\overline{\text{CS3}}$  set 16-bit bus and 3 waits.

By CS/WAIT controller, each chip selection signal's memory size, don't set actual connect memory size, need to set that logical address size: fitting to each local area. Actual physical address is set by each area's BANK register setting.

 ${
m CSEX}$  setting of CS/WAIT controller is except above CS0 to CS3's setting. This program example isn't used CSEX setting.

Finally pin condition is set. PORT60 to 65 set to  $\overline{\text{CS0}}$ ,  $\overline{\text{CS1}}$ ,  $\overline{\text{CS2}}$ ,  $\overline{\text{CS3}}$ , EA24, EA25 and SDRAM condition.

```
BANK Operation
;***** <del>CS2</del> *****
                                ; Program ROM: Start address at BANK0 of LOCAL2
ORG
       000000H
       200000H
                                ; Program ROM: Start address at BANK1 of LOCAL2
 ORG
 ORG
       400000H
                                 Program ROM: Start address at BANK2 of LOCAL2
 ORG
                                 Program ROM: Start address at BANK3 of LOCAL2
       600000H
ORG
       800000H
                                 Program ROM: Start address at BANK4 of LOCAL2
ORG
       A00000H
                                 Program ROM: Start address at BANK5 of LOCAL2
ORG
       C00000H
                                ; Program ROM: Start address at BANK6 of LOCAL2
 ORG
       E00000H
                                ; Program ROM: Start address at BANK7( = COMMON2) of LOCAL2
                                ; Logical address E00000H to FFFFFH
                                 Physical address 0E00000H to 0FFFFFH
                (LOCAL3),85H
       LD
                                 LOCAL3 BANK5 set 14xxxxH
       LDW
                HL,(800000H)_
                                 Load data (5555H) form BANK5 (140000H: Physical address)
                                                                 of LOCAL3 (CS3)
       LD
                (LOCAL3),88H
                                 LOCAL3 BANK8 set 20xxxxH
                                 Load data (AAAAH) form BANK8 (200000H: Physical address)
       LDW
                BC,(800000H)_
                                                                 of LOCAL3 (CS3)
l to
|ORG FFFFFFH
                                 Program ROM: End address at BANK7 ( = COMMON2) of LOCAL2
ORG
       0000000H
                                 Data ROM: Start address at BANK0 of LOCAL3
ORG
       0400000H
                                 Data ROM: Start address at BANK1 of LOCAL3
 ORG
       0800000H
                                 Data ROM: Start address at BANK2 of LOCAL3
                                 Data ROM: Start address at BANK3 of LOCAL3
 ORG
       0C00000H
 ORG
                                 Data ROM: Start address at BANK4 of LOCAL3
       1000000H
 ORG
       1400000H
                                 Data ROM: Start address at BANK5 of LOCAL3
       dw
                5555H
to
ORG
       1800000H
                                ; Data ROM: Start address at BANK6 of LOCAL3
 ORG
       1C00000H
                                ; Data ROM: Start address at BANK7 of LOCAL3
 ORG
       2000000H
                                 Data ROM: Start address at BANK8 of LOCAL3
       dw
                AAAAH 4
to
ORG
       2400000H
                                ; Data ROM: Start address at BANK9 of LOCAL3
                                ; Data ROM: Start address at BANK10 of LOCAL3
ORG
       2800000H
 ORG
       2C00000H
                                 Data ROM: Start address at BANK11 of LOCAL3
 ORG
                                 Data ROM: Start address at BANK12 of LOCAL3
       3000000H
                                 Data ROM: Start address at BANK13 of LOCAL3
 ORG
       3400000H
ORG
                                 Data ROM: Start address at BANK14 of LOCAL3
       3800000H
ORG
       3C00000H
                                 Data ROM: Start address at BANK15 of LOCAL3
ORG
       3FFFFFFH
                                 Data ROM: End address at BANK15 of LOCAL3
```

Figure 3.8.6 BANK Operation S/W Example 2

Here shows example of data access between one BANK and other BANK. Figure 3.8.6 is one software example. A dot line square area shows one memory and each dot line square shows  $\overline{\text{CS2}}$ 's program ROM and  $\overline{\text{CS3}}$ 's data ROM. Program start from E00000H address, firstly, write to BANK register of LOCAL3 area upper 5-bit address of access point.

In case of this example, because most upper address bit of physical address is EA25, most upper address bit of BANK register is meaningless. 4-bits of upper 5-bits address means 16 BANKs. After setting BANK5, accessing 800000H to BFFFFFH address: logical LOCAL3 address, actually access to physical 1400000H to 1700000H address.



Figure 3.8.7 Bank Operation S/W Example 3

At Figure 3.8.7, it shows example of program jump.

In the same way with before example, two dot line squares show each  $\overline{\text{CS2}}$ 's program ROM and  $\overline{\text{CS1}}$ 's (SDCS) SDRAM. Program start from E00000H COMMON address, firstly, write to BANK register of LOCAL2 area upper 3-bit address of jumping point.

After setting BANK1, jumping C00000H to DFFFFFH address: logical LOCAL2 address, actually jump to physical 200000H to 3FFFFFH address. When return to COMMON area, it can only jump to E00000H to FFFFFFH without writing to BANK register of LOCAL2 area.

By a way of setting of BANK register, the setting that BANK address and COMMON address conflict with is possible. When two kinds or more logical addresses to show COMMON area exist, management of BANK is confused. We recommend not using The BANK setting, BANK address and COMMON address conflict with.

When using LCD display data for SDRAM, we recommend setting display area to COMMON area in SDRAM. Because of, LCD displays DMA occur at sycronousless. If SDRAM BANK is changed, you don't need to care only COMMON area.

It is a mark paid attention to here, it needs to go by way of COMMON area by all means when moves from a BANK to a BANK. In other words, it must write to BANK register only in COMMON area and it prohibits writing the BANK registers in BANK area. If it modify the bank register's data in BANK area, program runaway.

Please do not set Bank function of MMU as display RAM. This is because reading LCDC display data is not controlled by the CPU. Therefore if BANK of display area is changed during LCD displaying, it cannot display. It is recommended to allocate display data to a COMMON area.

#### 3.9 Serial Channels

TMP91C820A includes three serial I/O channels. For each channels either UART mode (Asynchronous transmission) or I/O interface mode (Synchronous transmission) can be selected. (Channel 2 can be selected only UART mode.)

• I/O interface mode — Mode 0: For transmitting and receiving I/O data using the

synchronizing signal SCLK for extending I/O.

• UART mode — Mode 1: 7-bit data
Mode 2: 8-bit data
Mode 3: 9-bit data

In mode 1 and mode 2 a parity bit can be added. Mode 3 has a wakeup function for making the master controller start slave controllers via a serial link (A multi-controller system).

Figure 3.9.2, 3.9.3, 3.9.4 are block diagrams for each channel.

Each channel can be used independently.

Each channel operates in the same fashion except for the following points, hence only the operation of channel 0 is explained below.

Table 3.9.1 Differences between Channels 0 to 2

|           | Channel 0                                     | Channel 1                                    | Channel 2                |
|-----------|-----------------------------------------------|----------------------------------------------|--------------------------|
| Pin name  | TXD0 (PC0)<br>RXD0 (PC1)<br>CTS0 /SCLK0 (PC2) | TXD1 (PC3)<br>RXD1 (PC4)<br>CTS1/SCLK1 (PC5) | TXD2 (PB0)<br>RXD2 (PB1) |
| IrDA mode | Yes                                           | No                                           | No                       |

This chapter contains the following sections:

- 3.9.1 Block Diagrams
- 3.9.2 Operation of Each Circuit
- 3.9.3 SFRs
- 3.9.4 Operation in Each Mode
- 3.9.5 Support for IrDA



Figure 3.9.1 Data Formats

# 3.9.1 Block Diagrams

Figure 3.9.2 is a block diagram representing serial channel 0.



Figure 3.9.2 Block Diagram of the Serial Channel 0



Figure 3.9.3 Block Diagram of the Serial Channel 1



Figure 3.9.4 Block Diagram of the Serial Channel 2

## 3.9.2 Operation of Each Circuit

## (1) Prescaler, prescaler clock selects

There is a 6-bit prescaler for waking serial clock. The clock selected using SYSCR<PRCK1:0> is divided by 4 and input to the prescaler as  $\phi$ T0. The prescaler can be run by selecting the baud rate generator as the waking serial clock.

Table 3.9.2 shows prescaler clock resolution into the baud rate generator.

Table 3.9.2 Prescaler Clock Resolution to Baud Rate Generator

| Select System            | Select Prescaler             | Gear Value          | Prescaler Output Clock Resolution |                    |                     |                     |  |
|--------------------------|------------------------------|---------------------|-----------------------------------|--------------------|---------------------|---------------------|--|
| Clock<br><sysck></sysck> | Clock<br><prck1:0></prck1:0> | <gear2:0></gear2:0> | фТ0                               | φ <b>T</b> 2       | φТ8                 | φТ32                |  |
| 1 (fs)                   |                              | XXX                 | 2 <sup>2</sup> /fs                | 2 <sup>4</sup> /fs | 2 <sup>6</sup> /fs  | 2 <sup>8</sup> /fs  |  |
|                          |                              | 000 (fc)            | 2²/fc                             | 2 <sup>4</sup> /fc | 2 <sup>6</sup> /fc  | 2 <sup>8</sup> /fc  |  |
|                          | 00<br>(f <sub>FPH</sub> )    | 001 (fc/2)          | 2 <sup>3</sup> /fc                | 2 <sup>5</sup> /fc | 2 <sup>7</sup> /fc  | 2 <sup>9</sup> /fc  |  |
|                          |                              | 010 (fc/4)          | 2 <sup>4</sup> /fc                | 2 <sup>6</sup> /fc | 2 <sup>8</sup> /fc  | 2 <sup>10</sup> /fc |  |
| 0 (fc)                   |                              | 011 (fc/8)          | 2 <sup>5</sup> /fc                | 2 <sup>7</sup> /fc | 2 <sup>9</sup> /fc  | 2 <sup>11</sup> /fc |  |
|                          |                              | 100 (fc/16)         | 2 <sup>6</sup> /fc                | 2 <sup>8</sup> /fc | 2 <sup>10</sup> /fc | 2 <sup>12</sup> /fc |  |
|                          | 10<br>(fc/16 clock)          | XXX                 | -                                 | 2 <sup>8</sup> /fc | 2 <sup>10</sup> /fc | 2 <sup>12</sup> /fc |  |

## X: Don't care, -: Cannot be used

The baud rate generator selects between 4-clock inputs:  $\phi T0$ ,  $\phi T2$ ,  $\phi T8$ , and  $\phi T32$  among the prescaler outputs.

## (2) Baud rate generator

The baud rate generator is a circuit, which generates transmission and receiving clocks that determine the transfer rate of the serial channels.

The input clock to the baud rate generator,  $\phi T0$ ,  $\phi T2$ ,  $\phi T8$  or  $\phi T32$ , is generated by the 6-bit prescaler which is shared by the timers. One of these input clocks is selected using the BR0CR<BR0CK1:0> field in the baud rate generator control register.

The baud rate generator includes a frequency divider, which divides the frequency by 1 or N + (16 - K)/16 or 16 values, determining the transfer rate.

The transfer rate is determined by the settings of BR0CR<BR0ADDE, BR0S3:0> and BR0ADD<BR0K3:0>.

### • In UART mode

### (1) When BR0CR<BR0ADDE> = 0

The settings BR0ADD<BR0K3:0> are ignored. The baud rate generator divides the selected prescaler clock by N, which is set in BR0CK<BR0S3:0>. (N = 1, 2, 3 ... 16)

### (2) When BR0CR < BR0ADDE > 1

The N + (16 - K)/16 division function is enabled. The baud rate generator divides the selected prescaler clock by N + (16 - K)/16 using the value of N set in BR0CR<BR0S3:0> (N = 2, 3 ... 15) and the value of K set in BR0ADD<BR0K3:0>. (K = 1, 2, 3 ... 15)

Note: If N = 1 or N = 16, the N + (16 - K)/16 division function is disabled. Set BR0CR<BR0ADDE> to 0.

### • In I/O interface mode

The N + (16 - K)/16 division function is not available in I/O interface mode. Set BR0CR<BR0ADDE> to 0 before dividing by N.

The method for calculating the transfer rate when the baud rate generator is used is explained below.

- In UART mode
  Baud rate =  $\frac{\text{Input clock of baud rate generator}}{\text{Frequency divider for baud rate generator}} \div 16$
- In I/O interface mode
  Baud rate =  $\frac{\text{Input clock of baud rate generator}}{\text{Frequency divider for baud rate generator}} \div 2$

## • Integer divider (N divider)

For example, when the source clock frequency (fc) = 12.288 MHz, the input clock frequency =  $\phi$ T2 (fc/16), the frequency divider N (BR0CR<BR0S3:0>) = 5, and BR0CR<BR0ADDE> = 0, the baud rate in UART mode is as follows:

Note: The N + (16 - K)/16 division function is disabled and setting BR0ADD<BR0K3:0> is invalid.

## • N + (16 - K)/16 divider (Only UART mode)

Accordingly, when the source clock frequency (fc) = 4.8 MHz, the input clock frequency =  $\phi$ T0, the frequency divider N (BR0CR<BR0S3:0>) = 7, K (BR0ADD<BR0K3:0>) = 3, and BR0CR<BR0ADDE> = 1, the baud rate in UART mode is as follows:

\* Clock state System clock: High frequency (fc) Clock gear: 1 (fc) Prescaler clock: System clock

Baud rate = 
$$\frac{\text{fc/4}}{7 + (16 - 3)/16} \div 16$$

$$= 4.8 \times 10^6 \div 4 \div (7 + 13/16) \div 16 = 9600 \text{ (bps)}$$

Table 3.9.3 show examples of UART mode transfer rates.

Additionally, the external clock input is available in the serial clock. (Serial channels 0, 1). The method for calculating the baud rate is explained below:

## • In UART mode

Baud rate = external clock input frequency  $\div$  16 It is necessary to satisfy (External clock input cycle)  $\ge$  4/fc

#### • In I/O interface mode

Baud rate = external clock input frequency

It is necessary to satisfy (External clock input cycle) ≥ 16/fc

Table 3.9.3 Transfer Rate Selection (When baud rate generator is used and BR0CR<BR0ADDE> = 0)

|            | Input Clock                 |         |         |        |       |
|------------|-----------------------------|---------|---------|--------|-------|
| fc [MHz]   | Frequency Divider N         | φΤ0     | φT2     | φΤ8    | φT32  |
|            | (BR0CR <br0s3:0>)</br0s3:0> |         |         |        |       |
| 9.830400   | 2                           | 76.800  | 19.200  | 4.800  | 1.200 |
| <b>↑</b>   | 4                           | 38.400  | 9.600   | 2.400  | 0.600 |
| $\uparrow$ | 8                           | 19.200  | 4.800   | 1.200  | 0.300 |
| <b>↑</b>   | 0                           | 9.600   | 2.400   | 0.600  | 0.150 |
| 12.288000  | 5                           | 38.400  | 9.600   | 2.400  | 0.600 |
| <b>↑</b>   | A                           | 19.200  | 4.800   | 1.200  | 0.300 |
| 14.745600  | 2                           | 115.200 | 28.800  | 7.200  | 1.800 |
| <b>↑</b>   | 3                           | 76.800  | 19.200  | 4.800  | 1.200 |
| $\uparrow$ | 6                           | 38.400  | 9.600   | 2.400  | 0.600 |
| <b>↑</b>   | С                           | 19.200  | 4.800   | 1.200  | 0.300 |
| 19.6608    | 1                           | 307.200 | 76.800  | 19.200 | 4.800 |
| <b>↑</b>   | 2                           | 153.600 | 38.400  | 93.600 | 2.400 |
| <b>↑</b>   | 4                           | 76.800  | 19.10   | 4.800  | 1.200 |
| <b>↑</b>   | 8                           | 38.400  | 9.600   | 2.400  | 0.600 |
| <b>↑</b>   | 10                          | 19.200  | 4.800   | 1.200  | 0.300 |
| 22.1184    | 3                           | 115.200 | 28.800  | 7.200  | 1.800 |
| 24.576     | 1                           | 384.000 | 96.000  | 24.000 | 6.000 |
| $\uparrow$ | 2                           | 192.000 | 48.000  | 12.000 | 3.000 |
| $\uparrow$ | 4                           | 96.000  | 24.000  | 6.000  | 1.500 |
| $\uparrow$ | 5                           | 76.800  | 19.200  | 4.800  | 1.200 |
| $\uparrow$ | 8                           | 48.000  | 12.000  | 3.000  | 0.750 |
| $\uparrow$ | А                           | 38.400  | 9.600   | 2.400  | 0.600 |
| $\uparrow$ | 10                          | 24.000  | 6.000   | 1.500  | 0.375 |
| 27.0336    | В                           | 38.400  | 9.600   | 2.400  | 0.600 |
| 29.4912    | 1                           | 460.800 | 115.200 | 28.800 | 7.200 |
| <b></b>    | 3                           | 153.600 | 38.400  | 9.600  | 2.400 |
| <b></b>    | 4                           | 115.200 | 28.800  | 7.200  | 1.800 |
| <b></b>    | 6                           | 76.800  | 19.200  | 4.800  | 1.200 |
| <b></b>    | 9                           | 51.200  | 12.800  | 3.200  | 1.800 |
| <b></b>    | С                           | 38.400  | 9.600   | 2.400  | 1.600 |
| <b></b>    | F                           | 30.720  | 7.680   | 1.920  | 1.480 |
| <b>↑</b>   | 10                          | 28.800  | 7.200   | 1.800  | 0.450 |
| 31.9488    | D                           | 38.400  | 9.600   | 2.400  | 0.600 |
| 34.4064    | 7                           | 76.800  | 19.200  | 4.800  | 1.200 |

Note 1: Transfer rates in I/O interface mode are eight times faster than the values given above.

Note 2: The values in this table are calculated for when fc is selected as the system clock, the clock gear is set for fc and the system clock is the prescaler clock input.

Timer out clock (TA0TRG) can be used for source clock of UART mode only.

Calculation method the frequency of TAOTRG

Frequency of TA0TRG = Baud rate  $\times$  16

Note: The TMRA0 match detect signal cannot be used as the transfer clock in I/O interface mode.

### (3) Serial clock generation circuit

This circuit generates the basic clock for transmitting and receiving data.

#### In I/O interface mode

In SCLK output mode with the setting SC0CR<IOC> = 0, the basic clock is generated by dividing the output of the baud rate generator by 2, as described previously.

In SCLK input mode with the setting SC0CR<IOC> = 1, the rising edge or falling edge will be detected according to the setting of the SC0CR<SCLKS> register to generate the basic clock.

### • In UART mode

The SC0MOD0<SC1:0> setting determines whether the baud rate generator clock, the internal system clock fsys, the match detect signal from timer TMRA0 or the external clock (SCLK0) is used to generate the basic clock SIOCLK.

### (4) Receiving counter

The receiving counter is a 4-bit binary counter used in UART mode, which counts up the pulses of the SIOCLK clock. It takes 16 SIOCLK pulses to receive 1 bit of data; each data bit is sampled three times — on the 7th, 8th and 9th clock cycles.

The value of the data bit is determined from these three samples using the majority rule.

For example, if the data bit is sampled respectively as 1, 0 and 1 on 7th, 8th and 9th clock cycles, the received data bit is taken to be 1. A data bit sampled as 0, 0 and 1 is taken to be 0.

### (5) Receiving control

#### • In I/O interface mode

In SCLK output mode with the setting SCOCR<IOC> = 0, the RXDO signal is sampled on the rising or falling edge of the shift clock which is output on the SCLKO pin, according to the SCOCR<SCLKS> setting.

In SCLK input mode with the setting SC0CR<IOC> = 1, the RXD0 signal is sampled on the rising or falling edge of the SCLK0 input, according to the SC0CR<SCLKS> setting.

## • In UART mode

The receiving control block has a circuit, which detects a start bit using the majority rule. Received bits are sampled three times; when two or more out of three samples are 0, the bit is recognized as the start bit and the receiving operation commences.

The values of the data bits that are received are also determined using the majority rule.

### (6) The receiving buffers

To prevent overrun errors, the receiving buffers are arranged in a double-buffer structure.

Received data is stored one bit at a time in receiving buffer 1 (which is a shift register). When 7 bits or 8 bits of data have been stored in receiving buffer 1, the stored data is transferred to receiving buffer 2 (SC0BUF); this causes an INTRX0 interrupt to be generated. The CPU only reads receiving buffer 2 (SC0BUF). Even before the CPU reads receiving buffer 2 (SC0BUF), the received data can be stored in receiving buffer 1. However, unless receiving buffer 2 (SC0BUF) is read before all bits of the next data are received by receiving buffer 1, an overrun error occurs. If an overrun error occurs, the contents of receiving buffer 1 will be lost, although the contents of receiving buffer 2 and SC0CR<RB8> will be preserved.

SCOCR<RB8> is used to store either the parity bit – added in 8-bit UART mode – or the most significant bit (MSB) – in 9-bit UART mode.

In 9-bit UART mode the wakeup function for the slave controller is enabled by setting SC0MOD0<WU> to 1; in this mode INTRX0 interrupts occur only when the value of SC0CR<RB8> is 1.

### (7) Transmission counter

The transmission counter is a 4-bit binary counter which is used in UART mode and which, like the receiving counter, counts the SIOCLK clock pulses; a TXDCLK pulse is generated every 16 SIOCLK clock pulses.



Figure 3.9.5 Generation of the Transmission Clock

### (8) Transmission control

## • In I/O interface mode

In SCLK output mode with the setting SC0CR<IOC> = 0, the data in the transmission buffer is output one bit at a time to the TXD0 pin on the rising or falling edge of the shift clock which is output on the SCLK0 pin, according to the SC0CR<SCLKS> setting.

In SCLK input mode with the setting SC0CR<IOC> = 1, the data in the transmission buffer is output one bit at a time on the TXD0 pin on the rising or falling edge of the SCLK0 input, according to the SC0CR<SCLKS> setting.

## • In UART mode

When transmission data sent from the CPU is written to the transmission buffer, transmission starts on the rising edge of the next TXDCLK, generating a transmission shift clock TXDSFT.

### Handshake function

Use of  $\overline{\text{CTS}}$  pin allows data can be sent in units of one frame; thus, overrun errors can be avoided. The handshake functions is enabled or disabled by the SC0MOD<CTSE> setting.

When the  $\overline{\text{CTS0}}$  pin goes high on completion of the current data send, data transmission is halted until the  $\overline{\text{CTS0}}$  pin goes low again. However, the INTTX0 interrupt is generated, it requests the next data send to the CPU. The next data is written in the transmission buffer and data sending is halted.

Though there is no  $\overline{RTS}$  pin, a handshake function can be easily configured by setting any port assigned to be the  $\overline{RTS}$  function. The  $\overline{RTS}$  should be output high to request send data halt after data receive is completed by software in the RXD interrupt routine.



Figure 3.9.6 Handshake Function



Note 1: If the  $\overline{\text{CTS}}$  signal goes high during transmission, no more data will be sent after completion of the current transmission.

Note 2: Transmission starts on the first falling edge of the TXDCLK clock after the CTS signal has fallen.

Figure 3.9.7 CTS (Clear to send) Timing

#### (9) Transmission buffer

The transmission buffer (SC0BUF) shifts out and sends the transmission data written from the CPU form the least significant bit (LSB) in order. When all the bits are shifted out, the transmission buffer becomes empty and generates an INTTX0 interrupt.

## (10) Parity control circuit

When SCOCR<PE> in the serial channel control register is set to 1, it is possible to transmit and receive data with parity. However, parity can be added only in 7-bit UART mode or 8-bit UART mode. The SCOCR<EVEN> field in the serial channel control register allows either even or odd parity to be selected.

In the case of transmission, parity is automatically generated when data is written to the transmission buffer SC0BUF. The data is transmitted after the parity bit has been stored in SC0BUF<TB7> in 7-bit UART mode or in SC0MOD0<TB8> in 8-bit UART mode. SC0CR<PE> and SC0CR<EVEN> must be set before the transmission data is written to the transmission buffer.

In the case of receiving, data is shifted into receiving buffer 1, and the parity is added after the data has been transferred to receiving buffer 2 (SC0BUF), and then compared with SC0BUF<RB7> in 7-bit UART mode or with SC0CR<RB8> in 8-bit UART mode. If they are not equal, a parity error is generated and the SC0CR<PERR> flag is set.

### (11) Error flags

Three error flags are provided to increase the reliability of data reception.

#### 1. Overrun error <OERR>

If all the bits of the next data item have been received in receiving buffer 1 while valid data still remains stored in receiving buffer 2 (SC0BUF), an overrun error is generated.

(INTRX interrupt routine)

- 1) Read receiving buffer
- 2) Read error flag
- 3) If  $\langle OERR \rangle = 1$

then

- a) Set to disable receiving (Write 0 to SC0MOD0<RXE>)
- b) Wait to terminate current frame
- c) Read receiving buffer
- d) Read error flag
- e) Set to enable receiving (Write 1 to SC0MOD0<RXE>)
- f) Request to transmit again
- 4) Other

### 2. Parity error <PERR>

The parity generated for the data shifted into receiving buffer 2 (SC0BUF) is compared with the parity bit received via the RXD pin. If they are not equal, a parity error is generated.

#### 3. Framing error <FERR>

The stop bit for the received data is sampled three times around the center. If the majority of the samples are 0, a framing error is generated.

## (12) Timing generation

## a. In UART mode

## Receiving

| Mode                 | 9 Bits<br>(Note)             | 8 Bits + Parity<br>(Note)       | 8 Bits, 7 Bits + Parity, 7 Bits |
|----------------------|------------------------------|---------------------------------|---------------------------------|
| Interrupt timing     | Center of last bit (Bit8)    | Center of last bit (Parity bit) | Center of stop bit              |
| Framing error timing | Center of stop bit           | Center of stop bit              | Center of stop bit              |
| Parity error timing  | _                            | Center of last bit (Parity bit) | Center of stop bit              |
| Overrun error timing | Center of last bit<br>(Bit8) | Center of last bit (Parity bit) | Center of stop bit              |

Note: In 9 bits and 8 bits + parity modes, interrupts coincide with the ninth bit pulse.

Thus, when servicing the interrupt, it is necessary to wait for a 1-bit period (to allow the stop bit to be transferred) to allow checking for a framing error.

## Transmitting

| Mode             | 9 Bits                              | 8 Bits + Parity                     | 8 Bits, 7 Bits + Parity, 7 Bits     |
|------------------|-------------------------------------|-------------------------------------|-------------------------------------|
| Interrupt timing | Just before stop bit is transmitted | Just before stop bit is transmitted | Just before stop bit is transmitted |

### b. I/O interface

| Transmission interrupt | SCLK output mode | Immediately after last bit data.<br>(See figure 3.9.25)                                                                     |
|------------------------|------------------|-----------------------------------------------------------------------------------------------------------------------------|
| timing                 | SCLK input mode  | Immediately after rise of last SCLK signal rising mode, or immediately after fall in falling mode. (See figure 3.9.26)      |
| Receiving interrupt    | SCLK output mode | Timing used to transfer received to data receive buffer 2 (SC0BUF) (e.g., immediately after last SCLK). (See figure 3.9.27) |
| timing                 | SCLK input mode  | Timing used to transfer received data to receive buffer 2 (SC0BUF) (e.g., immediately after last SCLK). (See figure 3.9.28) |

## 3.9.3 SFRs



Figure 3.9.8 Serial Mode Control Register (Channel 0, SC0MOD0)



Figure 3.9.9 Serial Mode Control Register (Channel 1, SC1MOD0)



Figure 3.9.10 Serial Mode Control Register (Channel 2, SC2MOD0)



Note: As all error flags are cleared after reading, do not test only a single bit with a bit testing instruction.

Figure 3.9.11 Serial Control Register (Channel 0, SC0CR)



Note: As all error flags are cleared after reading, do not test only a single bit with a bit testing instruction.

Figure 3.9.12 Serial Control Register (Channel 1, SC1CR)



Note: As all error flags are cleared after reading, do not test only a single bit with a bit testing instruction.

Figure 3.9.13 Serial Control Register (Channel 2, SC2CR)



Note1:Availability of +(16-K)/16 division function

| N       | UART mode | I/O mode |
|---------|-----------|----------|
| 2 to 15 | 0         | ×        |
| 1 , 16  | ×         | ×        |

The baud rate generator can be set "1" in UART mode and disable +(16-K)/16 division function.Don't use in I/O interface mode.

Note2:Set BR0CR <BR0ADDE> to 1 after setting K (K = 1 to 15) to BR0ADD<BR0K3:0> when +(16-K)/16 division function is used. Writes to unused bits in the BR0ADD register do not affext operation, and undefined data is read from these unused bits.

Figure 3.9.14 Baud Rate Generator Control (Channel 0, BR0CR, BR0ADD)



Note1: Availability of +(16-K)/16 division function

| N       | UART mode | I/O mode |
|---------|-----------|----------|
| 2 to 15 | 0         | ×        |
| 1 , 16  | ×         | ×        |

The baud rate generator can be set "1" in UART mode and disable +(16-K)/16 division function. Don't use in I/O interface mode.

Note2:Set BR1CR <BR1ADDE> to 1 after setting K (K = 1 to 15) to BR1ADD<BR1K3:0> when +(16-K)/16 division function is used. Writes to unused bits in the BR1ADD register do not affext operation, and undefined data is read from these unused bits.

Figure 3.9.15 Baud Rate Generator Control (Channel 1, BR1CR, BR1ADD)



Note1: Availability of +(16-K)/16 division function

| N       | UART mode | I/O mode |
|---------|-----------|----------|
| 2 to 15 | 0         | ×        |
| 1,16    | ×         | ×        |

The baud rate generator can be set "1" in UART mode and disable +(16-K)/16 division function. Don't use in I/O interface mode.

Note2:Set BR2CR <BR2ADDE> to 1 after setting K (K = 1 to 15) to BR2ADD<BR2K3:0> when +(16-K)/16 division function is used. Writes to unused bits in the BR2ADD register do not affext operation, and undefined data is read from these unused bits

Figure 3.9.16 Baud Rate Generator Control (Channel 2, BR2CR, BR2ADD)



Note: Prohibit read-modify-write for SC0BUF.

Figure 3.9.17 Serial Transmission/Receiving Buffer Registers (Channel 0, SC0BUF)

|         |             | 7       | 6       | 5 | 4 | 3 | 2 | 1 | 0 |
|---------|-------------|---------|---------|---|---|---|---|---|---|
| SC0MOD1 | Bit symbol  | 12S0    | FDPX0   |   |   |   |   |   |   |
| (0205H) | Read/Write  | R/W     | R/W     |   |   |   |   |   |   |
|         | After reset | 0       | 0       |   |   |   |   |   |   |
|         | Function    | IDLE2   | Duplex  |   |   |   |   |   |   |
|         |             | 0: Stop | 0: Half |   |   |   |   |   |   |
|         |             | 1: Run  | 1: Full |   |   |   |   |   |   |

Figure 3.9.18 Serial Mode Control Register 1 (Channel 0, SC0MOD1)



Note: Prohibit read-modify-write for SC1BUF.

Figure 3.9.19 Serial Transmission/Receiving Buffer Registers (Channel 1, SC1BUF)

|         |             | 7       | 6       | 5 | 4 | 3 | 2 | 1 | 0 |
|---------|-------------|---------|---------|---|---|---|---|---|---|
| SC1MOD1 | Bit symbol  | I2S1    | FDPX1   |   |   |   |   |   |   |
| (020DH) | Read/Write  | R/W     | R/W     |   |   |   |   |   |   |
|         | After reset | 0       | 0       |   |   |   |   |   |   |
|         | Function    | IDLE2   | Duplex  |   |   |   |   |   |   |
|         |             | 0: Stop | 0: Half |   |   |   |   |   |   |
|         |             | 1: Run  | 1: Full |   |   |   |   |   |   |

Figure 3.9.20 Serial Mode Control Register 1 (Channel 1, SC1MOD1)



Note: Prohibit read-modify-write for SC2BUF.

Figure 3.9.21 Serial Transmission/Receiving Buffer Registers (Channel 2, SC2BUF)

|         |             | 7       | 6       | 5 | 4 | 3 | 2 | 1 | 0 |
|---------|-------------|---------|---------|---|---|---|---|---|---|
| SC2MOD1 | Bit symbol  | 12S2    | FDPX2   |   |   |   |   |   |   |
| (0215H) | Read/Write  | R/W     | R/W     |   |   |   |   |   |   |
|         | After reset | 0       | 0       |   |   |   |   |   |   |
|         | Function    | IDLE2   | Duplex  |   |   |   |   |   |   |
|         |             | 0: Stop | 0: Half |   |   |   |   |   |   |
|         |             | 1: Run  | 1: Full |   |   |   |   |   |   |

Figure 3.9.22 Serial Mode Control Register 1 (Channel 2, SC2MOD1)

## 3.9.4 Operation in Each Mode

### (1) Mode 0 (I/O interface mode)

This mode allows an increase in the number of I/O pins available for transmitting data to or receiving data from an external shift register.

This mode includes the SCLK output mode to output synchronous clock SCLK and SCLK input mode to input external synchronous clock SCLK.



Figure 3.9.23 SCLK Output Mode Connection Example



Figure 3.9.24 Example of SCLK Input Mode Connection

TOSHIBA

### a. Transmission

In SCLK output mode 8-bit data and a synchronous clock are output on the TXD0 and SCLK0 pins respectively each time the CPU writes the data to the transmission buffer. When all data is output, INTESO<ITX0C> will be set to generate the INTTX0 interrupt.



Figure 3.9.25 Transmitting Operation in I/O Interface Mode (SCLK0 output mode) (Channel 0)

In SCLK input mode, 8-bit data is output on the TXD0 pin when the SCLK0 input becomes active after the data has been written to the transmission buffer by the CPU.

When all data is output, INTESO<ITX0C> will be set to generate INTTX0 interrupt.



Figure 3.9.26 Transmitting Operation in I/O Interface Mode (SCLK0 input mode) (Channel 0)

TOSHIBA

### b. Receiving

In SCLK output mode, the synchronous clock is outputted from SCLK0 pin and the data is shifted to receiving buffer 1. This starts when the receive interrupt flag INTESO<IRX0C> is cleared by reading the received data. When 8-bit data are received, the data will be transferred to receiving buffer 2 (SC0BUF according to the timing shown below) and INTESO<IRX0C> will be set to generate INTRX0 interrupt.

The outputting for the first SCLK0 starts by setting SC0MOD0<RXE> to 1.



Figure 3.9.27 Receiving Operation in I/O Interface Mode (SCLK0 output mode) (Channel 0)

In SCLK input mode, the data is shifted to receiving buffer 1 when the SCLK input becomes active after the receive interrupt flag INTES0<IRX0C> is cleared by reading the received data. When 8-bit data is received, the data will be shifted to receiving buffer 2 (SC0BUF according to the timing shown below) and INTES0 <IRX0C> will be set again to be generate INTRX0 interrupt.



Figure 3.9.28 Receiving Operation in I/O Interface Mode (SCLK0 input mode) (Channel 0)

Note: The system must be put in the receive enable state (SCMOD0<RXE> = 1) before data can be received.

# c. Transmission and receiving (Full duplex mode)

When the full duplex mode is used, set the level of receive interrupt to 0 and set enable the level of transmit interrupt. In the transmit interrupt program, read the receiving buffer before setting the next transmit data.

The example is following.

Example: Channel 0, SCLK output Baud rate = 9600 bps fc = 14.7456 MHz

| * Clock state | System clock:   | High frequency (fc) |
|---------------|-----------------|---------------------|
|               | Clock gear:     | 1 (fc)              |
|               | Prescaler clock | :: feph             |

| Main routine |      |      |      |   |   |   |   |   |                                                                                 |
|--------------|------|------|------|---|---|---|---|---|---------------------------------------------------------------------------------|
|              | 7    | 6    | 5    | 4 | 3 | 2 | 1 | 0 | Set the INTTX0 level to 1.                                                      |
| INTES0       | 0    | 0    | 0    | 1 | 0 | 0 | 0 | 0 | Set the INTRX0 level to 0.                                                      |
| PCCR         | -    | -    | -    | - | - | 1 | 0 | 1 | Set PC0, PC1 and PC2 to function as the TXD0, RXD0 and SCLK0 pins respectively. |
| PCFC         | _    | -    | _    | _ | _ | 1 | - | 1 |                                                                                 |
| SC0MOD0      | 0    | 0    | 0    | 0 | 0 | 0 | 0 | 0 | Select I/O interface mode.                                                      |
| SC0MOD1      | 1    | 1    | 0    | 0 | 0 | 0 | 0 | 0 | Select full duplex mode.                                                        |
| SC0CR        | 0    | 0    | 0    | 0 | 0 | 0 | 0 | 0 | SCLK output, transmit on negative edge, receive on positive edge.               |
| BR0CR        | 0    | 0    | 1    | 1 | 0 | 0 | 1 | 1 | Baud rate = 9600 bps.                                                           |
| SC0MOD0      | 0    | 0    | 1    | 0 | 0 | 0 | 0 | 0 | Enable receiving.                                                               |
| SC0BUF       | *    | *    | *    | * | * | * | * | * | Set the transmit data and start.                                                |
| INTTX0 inter | rupt | rout | tine |   |   |   |   |   |                                                                                 |
| Acc SC0BUF   | =    |      |      |   |   |   |   |   | Read the receiving buffer.                                                      |
| SC0BUF       | *    | *    | *    | * | * | * | * | * | Set the next transmit data.                                                     |
|              |      |      |      |   |   |   |   |   |                                                                                 |

X: Don't care, -: No change

### (2) Mode 1 (7-bit UART mode)

7-bit UART mode is selected by setting the serial channel mode register SC0MOD0<SM1:0> field to 01.

In this mode a parity bit can be added. Use of a parity bit is enabled or disabled by the setting of the serial channel control register SC0CR<PE> bit; whether even parity or odd parity will be used is determined by the SC0CR<EVEN> setting when SC0CR<PE> is set to 1 (Enabled).

Example: When transmitting data of the following format, the control registers should be set as described below. This explanation applies to channel 0.



## (3) Mode 2 (8-bit UART mode)

8-bit UART mode is selected by setting SC0MOD0<SM1:0> to 10. In this mode a parity bit can be added (Use of a parity bit is enabled or disabled by the setting of SC0CR<PE>); whether even parity or odd parity will be used is determined by the SC0CR<EVEN> setting when SC0CR<PE> is set to 1 (Enabled).

Example: When receiving data of the following format, the control registers should be set as described below.



| * CI           | lock state                                         |   | System clock: High frequency (fc) Clock gear: 1 (fc) Prescaler clock: System clock |  |  |  |  |  |
|----------------|----------------------------------------------------|---|------------------------------------------------------------------------------------|--|--|--|--|--|
| Main settings  |                                                    |   |                                                                                    |  |  |  |  |  |
|                | 7 6 5 4 3 2 1 0                                    |   |                                                                                    |  |  |  |  |  |
| PCCR           | ← 0 -                                              |   | Set PC1 to function as the RXD0 pin.                                               |  |  |  |  |  |
| SC0MOD         | $\leftarrow$ - 0 1 X 1 0 0 1                       |   | Enable receiving in 8-bit UART mode.                                               |  |  |  |  |  |
| SC0CR          | $\leftarrow \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \$ |   | Add even parity.                                                                   |  |  |  |  |  |
| BR0CR          | $\leftarrow$ 0 0 0 1 0 1 0 1                       |   | Set the transfer rate to 9600 bps.                                                 |  |  |  |  |  |
| INTES0         | ← 1 1 0 0                                          |   | Enable the INTRX0 interrupt and set it to interrupt level 4.                       |  |  |  |  |  |
| Interrupt prod | cessing                                            |   |                                                                                    |  |  |  |  |  |
| Acc            | ← SC0CR AND 00011100                               | ١ |                                                                                    |  |  |  |  |  |
| if Acc         | ≠ 0 then ERROR                                     | } | Check for errors.                                                                  |  |  |  |  |  |
| Acc            | ← SC0BUF                                           | _ | Read the received data.                                                            |  |  |  |  |  |
| X: Don't care, | X: Don't care, -: No change                        |   |                                                                                    |  |  |  |  |  |

## (4) Mode 3 (9-bit UART mode)

9-bit UART mode is selected by setting SC0MOD0<SM1:0> to 11. In this mode parity bit cannot be added.

In the case of transmission the MSB (9th bit) is written to SC0MOD0<TB8>. In the case of receiving it is stored in SC0CR<RB8>. When the buffer is written and read, the MSB is read or written first, before the rest of the SC0BUF data.

## Wakeup function

In 9-bit UART mode, the wakeup function for slave controllers is enabled by setting SC0MOD0<WU> to 1. The interrupt INTRX0 occurs only when<RB8> = 1.



Note: The TXD pin of each slave controller must be in open-drain output mode.

Figure 3.9.29 Serial Link Using Wakeup Function

### Protocol

- a. Select 9-bit UART mode on the master and slave controllers.
- b. Set the SC0MOD0<WU> bit on each slave controller to 1 to enable data receiving.
- c. The master controller transmits one-frame data including the 8-bit select code for the slave controllers. The MSB (Bit8) <TB8> is set to 1.



- d. Each slave controller receives the above frame. Each controller checks the above select code against its own select code. The controller whose code matches clears its WU bit to 0.
- e. The master controller transmits data to the specified slave controller whose SC0MOD<WU> bit is cleared to 0. The MSB (Bit8) <TB8> is cleared to 0.



f. The other slave controllers (Whose <WU> bits remain at 1) ignore the received data because their MSB (Bit8 or <RB8>) are set to 0, disabling INTRX0 interrupts. The slave controller (WU bit = 0) can transmit data to the master controller, and it is possible to indicate the end of data receiving to the master controller by this transmission.

Example: To link two slave controllers serially with the master controller using the internal clock fsys as the transfer clock.



Since Serial Channels 0 and 1 operate in exactly the same way, channel 0 only is used for the purposes of this explanation.

## • Setting the master controller

| Main        |       |   |   |   |   |   |   |   |   |
|-------------|-------|---|---|---|---|---|---|---|---|
| PCCR        | ← -   | _ | _ | _ | _ | _ | 0 | 1 | ٦ |
| PCFC        | ← -   | _ | _ | _ | _ | _ | Χ | 1 | ſ |
| INTES0      | ← 1   | 1 | 0 | 0 | 1 | 1 | 0 | 1 |   |
|             |       |   |   |   |   |   |   |   |   |
| SC0MOD0     | ← 1   | 0 | 1 | 0 | 1 | 1 | 1 | 0 |   |
| SC0BUF      | ← 0   | 0 | 0 | 0 | 0 | 0 | 0 | 1 |   |
| INTTX0 inte | rrupt |   |   |   |   |   |   |   |   |
| SC0MOD0     | ← 0   | - | _ | _ | _ | _ | _ | _ |   |
| SC0BUF      | ← *   | * | * | * | * | * | * | * |   |
|             |       |   |   |   |   |   |   |   |   |

Set PC0 and PC1 to function as the TXD0 and RXD0 pins respectively.

Enable the INTTX0 interrupt and set it to interrupt level 4. Enable the INTRX0 interrupt and set it to interrupt level 5. Set f<sub>SYS</sub> as the transmission clock for 9-bit UART mode. Set the select code for slave controller 1.

Set TB8 to 0.

Set data for transmission.

## • Setting the slave controller

| Main    |              |   |   |   |   |   |   |   |   |   |
|---------|--------------|---|---|---|---|---|---|---|---|---|
| PCCR    | $\leftarrow$ | - | - | - | - | _ | - | 0 | 1 | ) |
| PCFC    | $\leftarrow$ |   |   |   |   |   |   |   |   |   |
| PCODE   | $\leftarrow$ | Χ | Χ | Χ | Χ | _ | Χ | Χ | 1 | J |
| INTES0  | $\leftarrow$ | 1 | 1 | 0 | 1 | 1 | 1 | 1 | 0 |   |
| SC0MOD0 | $\leftarrow$ | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 0 |   |

Select PC1 and PC0 to function as the RXD0 and TXD0 pins respectively (Open-drain output).

Enable INTRX0 and INTTX0.

Set <WU> to 1 in 9-bit UART transmission mode using  $f_{\mbox{\scriptsize SYS}}$  as the transfer clock.

INTRX0 interrupt
Acc ← SC0BUF
if Acc = select code

Then SC0MOD0  $\leftarrow$  ---0----Clear <WU> to 0.

## 3.9.5 Support for IrDA

SIO0 includes support for the IrDA 1.0 infrared data communication specification. Figure 3.9.30 shows the block diagram.



Figure 3.9.30 Block Diagram

### (1) Modulation of the transmission data

When the transmit data is 0, the modem outputs 1 to TXD0 pin with either 3/16 or 1/16 times for width of baud rate. The pulse width is selected by the SIRCR<PLSEL>. When the transmit data is 1, the modem outputs 0.



Figure 3.9.31 Transmission Example

### (2) Demodulation of the receive data

When the receive data is the effective width of pulse 1, the modem outputs 0 to SIO0. Otherwise the modem outputs 1 to SIO0. The effective pulse width is selected by SIRCR<SIRWD3:0>.



Figure 3.9.32 Receiving Example

# (3) Data format

The data format is fixed as follows:

• Data length: 8 bits

• Parity bits: none

• Stop bits: 1

### (4) SFR

Figure 3.9.33 shows the control register SIRCR. Set the data SIRCR during SIO0 is stopping. The following example describes how to set this register:

1) SIO setting

; Set the SIO to UART mode.

 $\downarrow$ 

2) LD (SIRCR), 07H

; Set the receive data pulse width to 16×.

3) LD (SIRCR), 37H

; TXEN, RXEN enable the transmission and receiving.

 $\downarrow$ 

4) Start transmission

; The modem operates as follows:

and receiving for SIO0 • SIO0 starts transmitting.

• IR receiver starts receiving.

### (5) Notes

1) Baud rate generator for IrDA

To generate baud rate for IrDA, use baud rate generator in SIO0 by setting "01" to SC0MOD0<SC1:0>. To use another source (TA0TRG, fsys and SCLK0 input) are not allowed.

2) As the IrDA 1.0 physical layer specification, the data transfer speed and infra-red pulse width is specified.

The IrDA 1.0 specification is defined in Table 3.9.5.

| Table 6.6.6 Bada Nate and Fallo Width Openingations |            |                               |                       |                       |                       |  |  |  |
|-----------------------------------------------------|------------|-------------------------------|-----------------------|-----------------------|-----------------------|--|--|--|
| Baud Rate                                           | Modulation | Rate Tolerance<br>(% of rate) | Pulse Width (Minimum) | Pulse Width (Typical) | Pulse width (Maximum) |  |  |  |
| 2.4 kbps                                            | RZI        | ±0.87                         | 1.41 μs               | 78.13 μs              | 88.55 μs              |  |  |  |
| 9.6 kbps                                            | RZI        | ±0.87                         | 1.41 μs               | 19.53 μs              | 22.13 μs              |  |  |  |
| 19.2 kbps                                           | RZI        | ±0.87                         | 1.41 μs               | 9.77 μs               | 11.07 μs              |  |  |  |
| 38.4 kbps                                           | RZI        | ±0.87                         | 1.41 μs               | 4.88 μs               | 5.96 μs               |  |  |  |
| 57.6 kbps                                           | RZI        | ±0.87                         | 1.41 μs               | 3.26 µs               | 4.34 μs               |  |  |  |
| 115.2 kbps                                          | RZI        | ±0.87                         | 1.41 μs               | 1.63 μs               | 2.23 μs               |  |  |  |

Table 3.9.5 Baud Rate and Pulse Width Specifications

The pulse width is defined either baud rate TX 3/16 or  $1.6 \mu s$  ( $1.6 \mu s$  is equal to 3/16 pulse width when baud rate is 115.2 kbps).

The TMP91C820A has the function selects the pulse width of transmission either 3/16 or 1/16. But 1/16 pulse width can be selected when the baud rate is equal or less than 38.4 kbps.

As the same reason, +(16 - K)/16 division function in the baud rate generator of SIO0 can not be used to generate 115.2 kbps baud rate.

Also when the 38.4 kbps and 1/16 pulse width, +(16-K)/16 division function can not be used.

Table 3.9.6 Baud Rate and Pulse Width for (16 – K)/16 Division Function

| Pulse Width | Baud Rate  |           |           |           |          |          |  |  |  |
|-------------|------------|-----------|-----------|-----------|----------|----------|--|--|--|
|             | 115.2 kbps | 57.6 kbps | 38.4 kbps | 19.2 kbps | 9.6 kbps | 2.4 kbps |  |  |  |
| T × 3/16    | ×          | 0         | 0         | 0         | 0        | 0        |  |  |  |
| T × 1/16    | _          | _         | ×         | 0         | 0        | 0        |  |  |  |

<sup>○:</sup> Can be used (16 - K)/16 division function.

 $<sup>\</sup>times$ : Can not be used (16 – K)/16 division function.

<sup>-:</sup> Can not be set to 1/16 pulse width.



Note: If pulse width complying with the IrDA 1.0 standard (1.6  $\mu s$  min.) can be guaranteed with a low baud rate, setting this bit to "1" shortens the duration of infrared ray activation, resulting in reduced power dissipation.

Figure 3.9.33 IrDA Control Register

# 3.10 Serial Bus Interface (SBI)

The TMP91C820A has a one-channel serial bus interface which employs a clocked synchronous 8-bit SIO mode and an  $I^2C$  bus mode.

The serial bus interface is connected to an external device through P71 (SDA) and P72 (SCL) in the I<sup>2</sup>C bus mode; and through P70 (SCK), P71 (SO), P72 (SI) in the clocked synchronous 8-bit SIO mode.

Each pin is specified as follows.

|                           | P7ODE <ode72, ode71=""></ode72,> | P7CR <p72c, p70c="" p71c,=""></p72c,> | P7FC <p72f, p70f="" p71f,=""></p72f,> |  |
|---------------------------|----------------------------------|---------------------------------------|---------------------------------------|--|
| I <sup>2</sup> C bus mode | 11                               | 11X                                   | 11X                                   |  |
| Clocked synchronous       | XX                               | 011                                   | 111                                   |  |
| 8-bit SIO mode            | **                               | 010                                   | 111                                   |  |

X: Don't care

## 3.10.1 Configuration



Figure 3.10.1 Serial Bus Interface (SBI)

## 3.10.2 Serial Bus Interface (SBI) Control

The following registers are used to control the serial bus interface and monitor the operation status.

- Serial bus interface control register 1 (SBI0CR1)
- Serial bus interface control register 2 (SBI0CR2)
- Serial bus interface data buffer register (SBI0DBR)
- I2C bus address register (I2C0AR)
- Serial bus interface status register (SBI0SR)
- Serial bus interface baud rate register 0 (SBI0BR0)
- Serial bus interface baud rate register 1 (SBI0BR1)

The above registers differ depending on a mode to be used.

Refer to section 3.10.4 "I<sup>2</sup>C Bus Mode Control" and 3.10.7 "Clocked Synchronous 8-Bit SIO Mode Control".

## 3.10.3 The Data Formats in the I<sup>2</sup>C Bus Mode

The data formats in the I<sup>2</sup>C bus mode is shown below.

### (a) Addressing format



## (b) Addressing format (with restart)



(c) Free data format (Data transferred from master device to slave device)



S: Start condition

R/W: Direction bit

ACK: Acknowledge bit

P: Stop condition

Figure 3.10.2 Data Format in the I<sup>2</sup>C Bus Mode

### 3.10.4 I<sup>2</sup>C Bus Mode Control

The following registers are used to control and monitor the operation status when using the serial bus interface (SBI) in the I<sup>2</sup>C bus mode.



Note 1: Set the <BC2:0> to 000 before switching to a clock synchronous 8-bit SIO mode.

Figure 3.10.3 Registers for the I<sup>2</sup>C Bus Mode

Note 2: For the frequency of the SCL line clock, see 3.10.5 (3) "Serial clock".

Note 3: Initial data of SCK0 is "0", SWRMON is "1".

Note 4: This I<sup>2</sup>C bus circuit dose not support fast mode, it supports standard mode only. Although the I<sup>2</sup>C bus circuit itself allows the setting of a baud rate over 100 kbps, the compliance with the I<sup>2</sup>C specification is not guaranteed in that case.



Serial Bus Interface Control Register 2

- Note 1: Reading this register function as SBI0SR register.
- Note 2: Switch a mode to port mode after confirming that the bus is free.

  Switch a mode between I<sup>2</sup>C bus mode and clock synchronous 8-bit SIO mode after confirming that input signals via port are high level.

Figure 3.10.4 Registers for the I<sup>2</sup>C Bus Mode



Figure 3.10.5 Registers for the I<sup>2</sup>C Bus Mode

#### Serial Bus Interface Baud Rate Regster 0 7 4 2 0 6 5 SBI0BR0 I2SBI0 Bit symbol (0244H)Read/Write W R/W 0 After reset 0 Prohibit Always IDLE2 read-Function write "0". modify-0: Stop write 1: Run Operation during IDLE 2 mode 0 Stop Operation Serial Bus Interface Baud Rate Register 1 6 5 4 3 2 0 SBI0BR1 Bit symbol P4EN (0245H) Read/Write W W After reset 0 0 Prohibit Always Internal Function readclock write "0". modify-0: Stop write 1: Operate Baud rate clock control 0 Stop Operate Sirial Bus Interface Data Buffer Register 6 5 4 0 1 DB7 DB6 DB5 DB4 DB3 DB2 DB1 DB0 SBI0DBR Bit symbol

(0241H) Prohibit

read-

modifywrite

Read/Write

After reset When writing transmitted data, start from the MSB (Bit7). Receiving data is placed from LSB (Bit0). Note 1:

Note 2: SBI0DBR can't be read the written data. Therefore read-modify-write instruction (e.g., "BIT" instruction) is prohibitted.

R (Received)/W (Transfer)

Undefined

Written data in SBI0DBR is cleared by INTSBI signal.

#### I<sup>2</sup>C Bus Address Register

| write mode                                                                                                                                                                        |                                |             |     |             |               |             |              |              |      |             |  |  |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------|-------------|-----|-------------|---------------|-------------|--------------|--------------|------|-------------|--|--|--|
| (0242H) Read/Write W After reset 0 0 0 0 0 0 0 0 0 0 0 0 Prohibit read-modify-write Slave address selection for when device is operating as slave device Address recognition mode |                                |             | 7   | 6           | 5             | 4           | 3            | 2            | 1    | 0           |  |  |  |
| After reset 0 0 0 0 0 0 0 0 0 0 0 Prohibit read-modify-write Slave address selection for when device is operating as slave device Address recognition mode                        | (0242H)  Prohibit read-modify- | Bit symbol  | SA6 | SA5         | SA4           | SA3         | SA2          | SA1          | SA0  | ALS         |  |  |  |
| Prohibit read-modify-write  Function  Slave address selection for when device is operating as slave device  Address recognition mode                                              |                                | Read/Write  |     | W           |               |             |              |              |      |             |  |  |  |
| read-modify-write  Function Slave address selection for when device is operating as slave device recognition mode                                                                 |                                | After reset | 0   | 0           | 0             | 0           | 0            | 0            | 0    | 0           |  |  |  |
| орозноше                                                                                                                                                                          |                                | Function    | Sla | ave address | selection for | when device | is operating | as slave dev | rice | recognition |  |  |  |

Address recognition mode specification

Slave address recognition Non slave address recognition

Figure 3.10.6 Registers for the I<sup>2</sup>C Bus Mode

# 3.10.5 Control in I<sup>2</sup>C Bus Mode

# (1) Acknowledge mode specification

Set the SBIOCR1<ACK> to 1 for operation in the acknowledge mode. The TMP91C820A generates an additional clock pulse for an acknowledge signal when operating in master mode. In the transmitter mode during the clock pulse cycle, the SDA pin is released in order to receive the acknowledge signal from the receiver. In the receiver mode during the clock pulse cycle, the SDA pin is set to the low in order to generate the acknowledge signal.

Clear the <ACK> to 0 for operation in the non-acknowledge mode. The TMP91C820A does not generate a clock pulse for the acknowledge signal when operating in the master mode.

#### (2) Number of transfer bits

The SBI0CR1<BC2:0> is used to select a number of bits for next transmitting and receiving data.

Since the <BC2:0> is cleared to 000 as a start condition, a slave address and direction bit transmission are executed in 8 bits. Other than these, the <BC2:0> retains a specified value.

#### (3) Serial clock

#### a. Clock source

The SBIOCR1<SCK2:0> is used to select a maximum transfer frequency outputted on the SCL pin in master mode. Set a communication baud rate that meets the  $I^2C$  bus specification, such as the shortest pulse width of  $t_{LOW}$ , based on the equations shown below.



Note 1: fSBI shows fFPH.

Note 2: It's prohibit to use fc/16 prescaler clock when using SBI block. (I<sup>2</sup>C bus and clock synchronous.)

Figure 3.10.7 Clock Source

#### b. Clock synchronization

In the I<sup>2</sup>C bus mode, in order to wired-AND a bus, a master device which pulls down a clock line to low level, in the first place, invalidate a clock pulse of another master device which generates a high-level clock pulse. The master device with a high-level clock pulse needs to detect the situation and implement the following procedure.

The TMP91C820A has a clock synchronization function for normal data transfer even when more than one master exists on the bus.

The example explains the clock synchronization procedures when two masters simultaneously exist on a bus.



Figure 3.10.8 Clock Synchronization

As master A pulls down the internal SCL output to the low level at point a, the SCL line of the bus becomes the low level. After detecting this situation, master B resets a counter of high-level width of an own clock pulse and sets the internal SCL output to the low level.

Master A finishes counting low-level width of an own clock pulse at point b and sets the internal SCL output to the high level. Since master B holds the SCL line of the bus at the low level, master A wait for counting high-level width of an own clock pulse. After master B finishes counting low-level width of an own clock pulse at point c and master A detects the SCL line of the bus at the high-level, and starts counting high level of an own clock pulse. The clock pulse on the bus is determined by the master device with the shortest high-level width and the master device with the longest low-level width from among those master devices connected to the bus.

### (4) Slave address and address recognition mode specification

When the TMP91C820A is used as a slave device, set the slave address <SA6:0> and <ALS> to the I2C0AR. Clear the <ALS> to 0 for the address recognition mode.

#### (5) Master/slave selection

Set the SBI0CR2<MST> to 1 for operating the TMP91C820A as a master device. Clear the SBI0CR2<MST> to 0 for operation as a slave device. The <MST> is cleared to 0 by the hardware after a stop condition on the bus is detected or arbitration is lost.

#### (6) Transmitter/receiver selection

Set the SBI0CR2<TRX> to 1 for operating the TMP91C820A as a transmitter. Clear the <TRX> to 0 for operation as a receiver. When data with an addressing format is transferred in slave mode, when a slave address with the same value that an I2C0AR or a GENERAL CALL is received (All 8-bit data are 0 after a start condition), the <TRX> is set to 1 by the hardware if the direction bit  $(R/\overline{W})$  sent from the master device is 1, and is cleared to 0 by the hardware if the bit is 0. In the master mode, after an acknowledge signal is returned from the slave device, the <TRX> is cleared to 0 by the hardware if a transmitted direction bit is 1, and is set to 1 by the hardware if it is 0. When an acknowledge signal is not returned, the current condition is maintained.

The <TRX> is cleared to 0 by the hardware after a stop condition on the I<sup>2</sup>C bus is detected or arbitration is lost.

# (7) Start/stop condition generation

When the SBI0SR<BB> is 0, slave address and direction bit which are set to SBI0DBR are output on a bus after generating a start condition by writing 1 to the SBI0CR2 <MST, TRX, BB, PIN>. It is necessary to set transmitted data to the data buffer register (SBI0DBR) and set 1 to <ACK> beforehand.



Figure 3.10.9 Start Condition Generation and Slave Address Generation

When the <BB> is 1, a sequence of generating a stop condition is started by writing 1 to the <MST, TRX, PIN>, and 0 to the <BB>. Do not modify the contents of <MST, TRX, BB, and PIN> until a stop condition is generated on a bus.



Figure 3.10.10 Stop Condition Generation

The state of the bus can be ascertained by reading the contents of SBI0SR<BB>. SBI0SR<BB> will be set to 1 if a start condition has been detected on the bus, and will be cleared to 0 if a stop condition has been detected.

And about generation of stop condition in master mode, there are some limitation point. Please refer to 3.10.6 (4) "Stop condition generation".

# (8) Interrupt service requests and interrupt cancellation

When a serial bus interface interrupt request (INTSBI) occurs, the SBIOCR2 <PIN> is cleared to 0. During the time that the SBIOCR2 <PIN> is 0, the SCL line is pulled down to the low level.

The <PIN> is cleared to 0 when a 1 word of data is transmitted or received. Either writing/reading data to/from SBI0DBR sets the <PIN> to 1.

The time from the  $\langle PIN \rangle$  being set to 1 until the SCL line is released takes  $t_{LOW}$ . In the address recognition mode ( $\langle ALS \rangle = 0$ ),  $\langle PIN \rangle$  is cleared to 0 when the received slave address is the same as the value set at the I2COAR or when a GENERAL CALL is received (All 8-bit data are 0 after a start condition). Although SBI0CR2 $\langle PIN \rangle$  can be set to 1 by the program, the  $\langle PIN \rangle$  is not clear it to 0 when it is written 0.

#### (9) Serial bus interface operation mode selection

SBI0CR2<SBIM1:0> is used to specify the serial bus interface operation mode. Set SBI0CR2<SBIM1:0> to 10 when the device is to be used in I<sup>2</sup>C bus mode after confirming pin condition of serial bus interface to "H".

Switch a mode to port after confirming a bus is free.

#### (10) Arbitration lost detection monitor

Since more than one master device can exist simultaneously on the bus in I<sup>2</sup>C bus mode, a bus arbitration procedure has been implemented in order to guarantee the integrity of transferred data.

Data on the SDA line is used for I<sup>2</sup>C bus arbitration.

The following shows an example of a bus arbitration procedure when two master devices exist simultaneously on the bus. Master A and master B output the same data until point a. After master A outputs L and master B, H, the SDA line of the bus is wire-AND and the SDA line is pulled down to the low-level by master A. When the SCL line of the bus is pulled up at point b, the slave device reads the data on the SDA line, that is, data in master A. A data transmitted from master B becomes invalid. The state in master B is called "ARBITRATION LOST". Master B device, which loses arbitration releases the internal SDA output in order not to affect data, transmitted from other masters with arbitration. When more than one master sends the same data at the first word, arbitration occurs continuously after the second word.



Figure 3.10.11 Arbitration Lost

The TMP91C820A compares the levels on the bus's SDA line with those of the internal SDA output on the rising edge of the SCL line. If the levels do not match, arbitration is lost and SBIOSR<AL> is set to 1.

When SBI0SR<AL> is set to 1, SBI0SR<MST, TRX> are cleared to 00 and the mode is switched to slave receiver mode. Thus, clock output is stopped in data transfer after setting  $\langle AL \rangle = "1"$ .

SBI0SR<AL> is cleared to 0 when data is written to or read from SBI0DBR or when data is written to SBI0CR2.



Figure 3.10.12 Example of when TMP91C820A is a Master Device B (D7A = D7B, D6A = D6B)

#### (11) Slave address match detection monitor

SBI0SR<AAS> is set to 1 in slave mode, in address recognition mode (e.g., when I2C0AR<ALS> = 0), when a GENERAL CALL is received, or when a slave address matches the value set in I2C0AR. When I2C0AR<ALS> = 1, SBI0SR<AAS> is set to 1 after the first word of data has been received. SBI0SR<AAS> is cleared to 0 when data is written to or read from the data buffer register SBI0DBR.

# (12) GENERAL CALL detection monitor

SBI0SR<AD0> is set to 1 in slave mode, when a GENERAL CALL is received (All 8-bit received data is 0, after a start condition). SBI0SR<AD0> is cleared to 0 when a start condition or stop condition is detected on the bus.

#### (13) Last received bit monitor

The SDA line value stored at the rising edge of the SCL line is set to the SBI0SR<LRB>. In the acknowledge mode, immediately after an INTSBI interrupt request is generated, an acknowledge signal is read by reading the contents of the SBI0SR<LRB>.

#### (14) Software reset function

The software reset function is used to initialize the SBI circuit, when SBI is rocked by external noises, etc.

An internal reset signal pulse can be generated by setting SBIOCR2<SWRST1:0> to 10 and 01. This initializes the SBI circuit internally. All command (except SBIOCR2<SBIM1:0>) registers and status registers are initialized as well.

SBI0CR1<SWRMON> is automatically set to 1 after the SBI circuit has been initialized.

# (15) Serial bus interface data buffer register (SBI0DBR)

The received data can be read and transferred data can be written by reading or writing the SBI0DBR.

In the master mode, after the start condition is generated the slave address and the direction bit are set in this register.

# (16) I2CBUS address register (I2C0AR)

I2C0AR<SA6:0> is used to set the slave address when the TMP91C820A functions as a slave device.

The slave address output from the master device is recognized by setting the I2C0AR<ALS> to 0. The data format is the addressing format. When the slave address is not recognized at the <ALS> = 1, the data format is the free data format.

#### (17) Baud rate register (SBI0BR1)

Write 1 to SBI0BR1<P4EN> before operation commences.

# (18) Setting register for IDLE2 mode operation (SBI0BR0)

SBI0BR0<I2SBI0> is the register setting operation/stop during IDLE2 mode. Therefore, setting <I2SBI0> is necessary before the HALT instruction is executed.

# 3.10.6 Data Transfer in I<sup>2</sup>C Bus Mode

#### (1) Device initialization

Set the SBI0BR1<P4EN>, SBI0CR1<ACK, SCK2:0>, set SBI0BR1 to 1 and clear bits 7 to 5 and 3 in the SBI0CR1 to 0.

Set a slave address  $\leq$ SA6:0> and the  $\leq$ ALS> ( $\leq$ ALS> = 0 when an addressing format) to the I2C0AR.

For specifying the default setting to a slave receiver mode, clear 0 to the <MST, TRX, BB> and set 1 to the <PIN>, 10 to the <SBIM1:0>.

# (2) Start condition and slave address generation

#### a. Master mode

In the master mode, the start condition and the slave address are generated as follows.

Check a bus free status (when  $\langle BB \rangle = 0$ ).

Set the SBIOCR1<ACK> to 1 (Acknowledge mode) and specify a slave address and a direction bit to be transmitted to the SBIODBR.

When SBI0CR2<BB> = 0, the start condition are generated by writing 1111 to SBI0CR2<MST, TRX, BB, PIN>. Subsequently to the start condition, nine clocks are output from the SCL pin. While eight clocks are output, the slave address and the direction bit which are set to the SBI0DBR. At the 9th clock, the SDA line is released and the acknowledge signal is received from the slave device.

An INTS2 interrupt request occurs at the falling edge of the 9th clock. The <PIN> is cleared to 0. In the master mode, the SCL pin is pulled down to the low-level while <PIN> is 0. When an interrupt request occurs, the <TRX> is changed according to the direction bit only when an acknowledge signal is returned from the slave device.

#### b. Slave mode

In the slave mode, the start condition and the slave address are received.

After the start condition is received from the master device, while eight clocks are output from the SCL pin, the slave address and the direction bit which are output from the master device are received.

When a GENERAL CALL or the same address as the slave address set in I2C0AR is received, the SDA line is pulled down to the low level at the 9th clock, and the acknowledge signal is output.

An INTSBI interrupt request occurs on the falling edge of the 9th clock. The <PIN> is cleared to 0. In slave mode the SCL line is pulled down to the low level while the <PIN> = 0.



Figure 3.10.13 Start Condition Generation and Slave Address Transfer

#### (3) 1-word data transfer

Check the <MST> by the INTSBI interrupt process after the 1-word data transfer is completed, and determine whether the mode is a master or slave.

#### a. If $\langle MST \rangle = 1$ (Master mode)

Check the <TRX> and determine whether the mode is a transmitter or receiver.

# When the $\langle TRX \rangle = 1$ (Transmitter mode)

Check the <LRB>. When <LRB> is 1, a receiver does not request data. Implement the process to generate a stop condition (Refer to 3.10.6 (4)) and terminate data transfer.

When the <LRB> is 0, the receiver is requests new data. When the next transmitted data is 8 bits, write the transmitted data to SBI0DBR. When the next transmitted data is other than 8 bits, set the <BC2:0>, set the <ACK> to 1 and write the transmitted data to SBI0DBR. After written the data, <PIN> becomes 1, a serial clock pulse is generated for transferring a new 1 word of data from the SCL pin, and then the one-word data is transmitted. After the data is transmitted, an INTSBI interrupt request occurs. The <PIN> becomes 0 and the SCL line is pulled down to the low level. If the data to be transferred is more than one word in length, repeat the procedure from the <LRB> checking above.



Figure 3.10.14 Example in which <BC2:0> = 000 and <ACK> = 1 in Transmitter Mode

# When the $\langle TRX \rangle = 0$ (Receiver mode)

When the next transmitted data is other than 8 bits, set <BC2:0> again. Set <ACK> to 1 and read the received data from SBI0DBR to release the SCL line (Data which is read immediately after a slave address is sent is undefined). After the data is read, <PIN> becomes 1.

Serial clock pulse for transferring new 1 data is defined SCL and outputs "L" level from SDA pin with acknowledge timing.

An INTSBI interrupt request then occurs and the <PIN> becomes 0. Then the TMP91C820A pulls down the SCL pin to the low level. The TMP91C820A outputs a clock pulse for 1 word of data transfer and the acknowledge signal each time that received data is read from the SBI0DBR.



Figure 3.10.15 Example of when <BC2:0> = 000, <ACK> = 1 in Receiver Mode

In order to terminate the transmission of data to a transmitter, clear <ACK> to 0 before reading data which is 1 word before the last data to be received. The last data word does not generate a clock pulse as the acknowledge signal. After the data has been transmitted and an interrupt request has been generated, set <BC2:0> to 001 and read the data. The TMP91C820A generates a clock pulse for a 1-bit data transfer. Since the master device is a receiver, the SDA line on the bus remains high. The transmitter interprets the high signal as an ACK signal. The receiver indicates to the transmitter that data transfer is complete.

After the one data bit has been received and an interrupt request been generated, the TMP91C820A generates a stop condition (See Section 3.10.6 (4)) and terminates data transfer.



Figure 3.10.16 Termination of Data Transfer in Master Receiver Mode

#### b. If $\langle MST \rangle = 0$ (Slave mode)

In the slave mode the TMP91C820A operates either in normal slave mode or in slave mode after losing arbitration.

In the slave mode, an INTSBI interrupt request occurs when the TMP91C820A receives a slave address or a GENERAL CALL from the master device, or when a GENERAL CALL is received and data transfer is complete, or after matching received address. In the master mode, the TMP91C820A operates in a slave mode if it losing arbitration. An INTSBI interrupt request occurs when a word data transfer terminates after losing arbitration. When an INTSBI interrupt request occurs the <PIN> is cleared to 0 and the SCL pin is pulled down to the low-level. Either reading/writing from/to the SBI0DBR or setting the <PIN> to 1 will release the SCL pin after taking tLow time.

Check the SBIOSR<AL>, <TRX>, <AAS>, and <ADO> and implements processes according to conditions listed in the next table.

Table 3.10.1 Operation in the Slave Mode

| <trx></trx> | <al></al> | <aas></aas> | <ad0></ad0> | Conditions                                                                                                                                                                              | Process                                                                                                                                                                                                                                                                                                       |
|-------------|-----------|-------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1           | 1         | 1           | 0           | The TMP91C820A loses arbitration when transmitting a slave address and receives a slave address for which the value of the direction bit sent from another master is 1.                 | Set the number of bits a word in<br><bc2:0> and write the transmitted<br/>data to SBI0DBR.</bc2:0>                                                                                                                                                                                                            |
|             | 0         | 1           | 0           | In salve receiver mode the TMP91C820A receives a slave address for which the value of the direction bit sent from the master is 1.                                                      |                                                                                                                                                                                                                                                                                                               |
|             |           | 0           | 0           | In salve transmitter mode a single word of is transmitted.  Set <bc2:0> to the number of bits in a word.</bc2:0>                                                                        | Check the <lrb> setting. If <lrb> is set to 1, set <pin> to 1 since the receiver win no request the data which follows. Then, clear <trx> to 0 to release the bus. If <lrb> is cleared to 0 of and write the transmitted data to SBI0DBR since the receiver requests next data.</lrb></trx></pin></lrb></lrb> |
| 0           | 1         | 1           | 1/0         | The TMP91C820A loses arbitration when transmitting a slave address and receives a slave address or GENERAL CALL for which the value of the direction bit sent from another master is 0. | Read the SBI0DBR for setting the<br><pin> to 1 (Reading dummy data)<br/>or set the <pin> to 1.</pin></pin>                                                                                                                                                                                                    |
|             |           | 0           | 0           | The TMP91C820A loses arbitration when transmitting a slave address or data and terminates word data transfer.                                                                           |                                                                                                                                                                                                                                                                                                               |
|             | 0         | 1           | 1/0         | In slave receiver mode the TMP91C820A receives a slave address or GENERAL CALL for which the value of the direction bit sent from the master is 0.                                      |                                                                                                                                                                                                                                                                                                               |
|             |           | 0           | 1/0         | In slave receiver mode the TMP91C820A terminates receiving word data.                                                                                                                   | Set <bc2:0> to the number of bits in<br/>a word and read the received data<br/>from SBI0DBR.</bc2:0>                                                                                                                                                                                                          |

# (4) Stop condition generation

When the SBIOSR<BB> is "1", the sequence of generating a stop condition is started by setting "111" to the SBIOCR2<MST, TRX, PIN> and "0" to the SBIOCR2<BB>. Do not modify the contents of the SBIOCR2<MST, TRX, PIN, BB> until a stop condition is generated on a bus. When a SCL line of bus is pulled down by other devices, this device generates a stop condition after they release a SCL line and the SDA becomes "1".



Figure 3.10.17 Stop Condition Generation (Single master)



Figure 3.10.18 Stop Condition Generation (Multi master)

#### (5) Restart

Restart is used to change the direction of data transfer between a master device and a slave device during transferring data. The following explains how to restart when the TMP91C820A is in the master mode.

Clear 0 to the SBIOCR2<MST, TRX, BB>, and set 1 to the <PIN> and release the bus. The SDA line remains the high level and the SCL pin is released. Since a stop condition is not generated on a bus, a bus is assumed to be in a busy state from other devices. Check the SBIOSR<BB> until it becomes 0 to check that the TMP91C820A is released. Check the <LRB> until it becomes 1 to check that the SCL line on a bus is not pulled down to the low level by other devices. After confirming that a bus stays in a free state, generate a start condition with procedure 3.10.6 (2).

In order to meet setup time when restarting, take at least 4.7 µs of waiting time by software from the time of restarting to confirm that the bus is free until the time to generate the start condition.



Figure 3.10.19 Timing Diagram for TMP91C820A Restart

#### 3.10.7 Clocked Synchronous 8-Bit SIO Mode control

The following registers are used to control and monitor the operation status when the serial bus interface (SBI) is being operated in clocked synchronous 8-bit SIO mode.



Note: Set the tranfer mode and the serial clock after setting <SIOS> to 0 and <SIOINH> to 1.

|                               | Serial Bus Interface Data Buffer Register |                           |     |   |   |   |   |   |   |  |  |  |
|-------------------------------|-------------------------------------------|---------------------------|-----|---|---|---|---|---|---|--|--|--|
| SBI0DBR                       |                                           | 7                         | 6   | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |
| (0241H) Prohibit read-modify- | Bit symbol                                | DB7                       | DB7 |   |   |   |   |   |   |  |  |  |
|                               | Read/Write                                | R (Receiver)/W (Transfer) |     |   |   |   |   |   |   |  |  |  |
|                               | After reset                               | Undefined                 |     |   |   |   |   |   |   |  |  |  |
| write                         |                                           |                           |     |   |   |   |   |   |   |  |  |  |

Figure 3.10.20 Register for the SIO Mode (1/3)

#### Serial Bus Interface Control Register 2 2 6 5 4 1 0 SBIM1 SBIM0 Bit symbol SBI0CR2 (0242H)Read/Write W W W After reset 0 0 0 0 (Note 2) (Note 2) Prohibit Serial bus interface Function read-modifyoperation mode selection 00: Port mode write 01: SIO mode 10: I2C bus mode 11: (Reserved) Serial bus interface operation mode selection Port mode (Serial bus interface output disabled)

Note 1: Set the SBI0CR1<BC2:0> 000 before switching to a clocked synchronous 8-bit SIO mode.

01 10

I<sup>2</sup>C bus mode (Reserved)

Clocked synchronous 8-bit SIO mode

Note 2: Please always write "00" to SBICR2<1:0>.

# Serial Bus Interface Status Register



Figure 3.10.21 Registers for the SIO Mode (2/3)



Figure 3.10.22 Registers for the SIO Mode (3/3)

#### (1) Serial Clock

#### a. Clock source

SBI0CR1<SCK2:0> is used to select the following functions:

# Internal clock

In internal clock mode one of seven frequencies can be selected. The serial clock signal is output to the outside on the SCK pin. When the device is writing (in transmit mode) or reading (in receive mode), data cannot follow the serial clock rate, so an automatic wait function is executed which automatically stops the serial clock and holds the next shift operation until reading or writing has been completed.



Figure 3.10.23 Automatic Wait Function

# External clock ( $\langle SCK2:0 \rangle = 111$ )

An external clock input via the SCK pin is used as the serial clock. In order to ensure the integrity of shift operations, both the high and low-level serial clock pulse widths shown below must be maintained. The maximum data transfer frequency is  $2.3 \, \text{MHz}$  (when fc =  $36 \, \text{MHz}$ ).



Figure 3.10.24 Maximum Data Transfer Frequency when External Clock Input Used

# b. Shift edge

Data is transmitted on the leading edge of the clock and received on the trailing edge.

# Leading edge shift

Data is shifted on the leading edge of the serial clock (on the falling edge of the SCK pin input/output).

# Trailing edge shift

Data is shifted on the trailing edge of the serial clock (on the rising edge of the SCK pin input/output).



Figure 3.10.25 Shift Edge

#### (2) Transfer modes

The SBI0CR1<SIOM1:0> is used to select a transmit, receive or transmit/receive mode.

#### a. 8-bit transmit mode

Set a control register to a transmit mode and write transmit data to the SBIODBR.

After the transmit data is written, set the SBI0CR1<SIOS> to 1 to start data transfer. The transmitted data is transferred from SBI0DBR to the shift register and output to the SO pin in synchronized with the serial clock, starting from the least significant bit (LSB), When the transmission data is transferred to the shift register, the SBI0DBR becomes empty. An INTSBI (Buffer empty) interrupt request is generated to request new data.

When the internal clock is used, the serial clock will stop and automatic-wait function will be initiated if new data is not loaded to the data buffer register after the specified 8-bit data is transmitted. When new transmit data is written, automatic-wait function is canceled.

When the external clock is used, data should be written to SBIODBR before new data is shifted. The transfer speed is determined by the maximum delay time between the time when an interrupt request is generated and the time when data is written to SBIODBR by the interrupt service program.

When the transmit is started, after the SBI0SR<SIOF> goes 1 output from the SO pin holds final bit of the last data until falling edge of the SCK.

Transmitting data is ended by clearing the <SIOS> to 0 by the buffer empty interrupt service program or setting the <SIOINH> to 1. When the <SIOS> is cleared, the transmitted mode ends when all data is output. In order to confirm if data is surely transmitted by the program, set the <SIOF> (Bit3 of SBIOSR) to be sensed. The SBIOSR<SIOF> is cleared to 0 when transmitting is complete. When the <SIOINH> is set to 1, transmitting data stops. SBIOSR<SIOF> turns 0.

When an external clock is used, it is also necessary to clear SBIOSR<SIOS> to 0 before new data is shifted; otherwise, dummy data is transmitted and operation ends.



Example: Program to stop data transmission (when an external clock is used)

Figure 3.10.26 Transfer Mode

(b) External clock

STEST1: BIT 2, (SBI0SR) ; If  $\langle SEF \rangle = 1$  then loop

JRNZ, STEST1

Write transmitted data

STEST2: BIT 0, (P7) ; If SCK = 0 then loop

JRZ, STEST2

LD (SBI0CR1), 00000111B ; <SIOS>  $\leftarrow$  0

# b. 8-bit receive mode SCK pin SIOF SO pin Bit6 Bit7 t\_SODH = Min 3.5/f\_PH [s]

Figure 3.10.27 Transmitted Data Hold Time at End of Transmission

Set the control register to receive mode and set SBI0CR1<SIOS> to 1 for switching to receive mode. Data is received into the shift register via the SI pin and synchronized with the serial clock, starting from the least significant bit (LSB). When 8-bit data is received, the data is transferred from the shift register to SBI0DBR. An INTSBI (Buffer full) interrupt request is generated to request that the received data be read. The data is then read from SBI0DBR by the interrupt service program.

When an internal clock is used, the serial clock will stop and the automatic wait function will be in effect until the received data has been read from SBIODBR.

When an external clock is used, since shift operation is synchronized with an external clock pulse, the received data should be read from SBI0DBR before the next serial clock pulse is input. If the received data is not read, any further data, which is to be received, is canceled. The maximum transfer speed when an external clock is used is determined by the delay time between the time when an interrupt request is generated and the time when the received data is read.

Receiving of data ends when <SIOS> is cleared to 0 by the buffer full interrupt service program or when <SIOINH> is set to 1. If <SIOS> is cleared to 0, received data is transferred to SBI0DBR in complete blocks. The received mode ends when the transfer is complete. In order to confirm whether data is being received properly by the program, set SBI0SR<SIOF> to be sensed. <SIOF> is cleared to 0 when receiving has been completed. When it is confirmed that receiving has been completed, the last data is read. When <SIOINH> is set to 1, data receiving stops. <SIOF> is cleared to 0. (The received data becomes invalid, therefore no need to read it.)

Note: When the transfer mode is changed, the contents of SBI0DBR will be lost. If the mode must be changed, conclude data receiving by clearing <SIOS> to 0, read the last data, and then change the mode.



Figure 3.10.28 Receiver Mode (Example: Internal clock)

#### c. 8-bit transmit/receive mode

Set a control register to a transmit/receive mode and write data to SBI0DBR. After the data has been written, set SBI0CR<SIOS> to 1 to start transmitting/receiving. When data is transmitted, the data is output via the SO pin, starting from the least significant bit (LSB) and synchronized with the leading edge of the serial clock signal. When data is received, the data is input via the SI pin on the trailing edge of the serial clock signal. 8-bit data is transferred from the shift register to SBI0DBR and an INTSBI interrupt request is generated. The interrupt service program reads the received data from the data buffer register and writes the data which is to be transmitted. SBI0DBR is used for both transmitting and receiving. Transmitted data should always be written after received data has been read.

When an internal clock is used, the automatic wait function will be in effect until the received data has been read and the next data has been written.

When an external clock is used, since the shift operation is synchronized with the external clock, received data is read and transmitted data is written before a new shift operation is executed. The maximum transfer speed when an external clock is used is determined by the delay time between the time when an interrupt request is generated and the time at which received data is read and transmitted data is written.

When the transmit is started, after the SBI0SR<SIOF> goes 1 output from the SO pin holds final bit of the last data until falling edge of the SCK.

Transmitting/receiving data ends when <SIOS> is cleared to 0 by the INTSBI interrupt service program or when SBI0CR1<SIOINH> is set to 1. When <SIOS> is cleared to 0, received data is transferred to SBI0DBR in complete blocks. The transmit/receive mode ends when the transfer is complete. In order to confirm whether data is being transmitted/received properly by the program; set SBI0SR to be sensed. <SIOF> is set to 0 when transmitting/receiving has been completed. When <SIOINH> is set to 1, data transmitting/receiving stops. <SIOF> is then cleared to 0.

Note: When the transfer mode is changed, the contents of SBI0DBR will be lost. If the mode must be changed, conclude data transmitting/receiving by clearing <SIOS> to 0, read the last data, then change the transfer mode.



Figure 3.10.29 Transmit/Received Mode (Example using internal clock)



Figure 3.10.30 Transmitted Data Hold Time at End of Transmit/Receive

# 3.11 Analog/Digital Converter

The TMP91C820A incorporates a 10-bit successive approximation-type analog/digital converter (AD converter) with 8-channel analog input.

Figure 3.11.1 is a block diagram of the AD converter. The 8-channel analog input pins (AN0 to AN7) are shared with the input-only port 8 and can thus be used as an input port.

Note: When IDLE2, IDLE1 or STOP mode is selected, so as to reduce the power, with some timings the system may enter a standby mode even though the internal comparator is still enabled. Therefore be sure to check that AD converter operations are halted before a HALT instruction is executed.



Figure 3.11.1 Block Diagram of AD Converter

# 3.11.1 Analog/Digital Converter Registers

The two AD mode control registers control the AD converter: ADMOD0 and ADMOD1. The eight AD conversion data upper and lower registers (ADREG04H/L, ADREG15H/L, ADREG26H/L and ADREG37H/L) store the results of AD conversion.

Figure 3.11.2 shows the registers related to the AD converter.



Figure 3.11.2 AD Converter Related Register



Note: As pin AN3 also functions as the  $\overline{ADTRG}$  input pin, do not set <ADCH2:0> = 011 when using  $\overline{ADTRG}$  with <ADTRGE> set to 1.

Figure 3.11.3 AD Converter Related Register

# AD Conversion Data Low Register 0/4

ADREG04L (02A0H)

| ĺ |             | 7                       | 6                          | 5 | 4 | 3 | 2 | 1 | 0                                                          |
|---|-------------|-------------------------|----------------------------|---|---|---|---|---|------------------------------------------------------------|
| I | Bit symbol  | ADR01                   | ADR00                      |   |   |   |   |   | ADR0RF                                                     |
|   | Read/Write  | F                       | ₹                          |   |   |   |   |   | R                                                          |
|   | After reset | Unde                    | fined                      |   |   |   |   |   | 0                                                          |
|   | Function    | Stores lower conversion | 2 bits of AD<br>on result. |   |   |   |   |   | AD conversion data storage flag 1:Conversion result stored |

# AD Conversion Data Upper Register 0/4

ADREG04H (02A1H)

|             | 7     | 6                                         | 5     | 4     | 3     | 2     | 1     | 0     |
|-------------|-------|-------------------------------------------|-------|-------|-------|-------|-------|-------|
| Bit symbol  | ADR09 | ADR08                                     | ADR07 | ADR06 | ADR05 | ADR04 | ADR03 | ADR02 |
| Read/Write  |       | R                                         |       |       |       |       |       |       |
| After reset |       | Undefined                                 |       |       |       |       |       |       |
| Function    |       | Stores upper 8 bits AD conversion result. |       |       |       |       |       |       |

# AD Conversion Data Lower Register 1/5

ADREG15L (02A2H)

|             | 7     | 6                            | 5 | 4 | 3 | 2 | 1 | 0                                                    |
|-------------|-------|------------------------------|---|---|---|---|---|------------------------------------------------------|
| Bit symbol  | ADR11 | ADR10                        |   |   |   |   |   | ADR1RF                                               |
| Read/Write  | F     | ₹                            |   |   |   |   |   | R                                                    |
| After reset | Unde  | fined                        |   |   |   |   |   | 0                                                    |
| Function    |       | · 2 bits of AD<br>on result. |   |   |   |   |   | AD conversion result flag 1:Conversion result stored |

# AD Conversion Data Upper Register 1/5

ADREG15H (02A3H)

|   |             | 7     | 6                                            | 5     | 4     | 3     | 2     | 1     | 0     |
|---|-------------|-------|----------------------------------------------|-------|-------|-------|-------|-------|-------|
| ┩ | Bit symbol  | ADR19 | ADR18                                        | ADR17 | ADR16 | ADR15 | ADR14 | ADR13 | ADR12 |
|   | Read/Write  |       | R                                            |       |       |       |       |       |       |
| Ì | After reset |       | Undefined                                    |       |       |       |       |       |       |
| Ì | Function    |       | Stores upper 8 bits of AD conversion result. |       |       |       |       |       |       |

Channel x conversion result



- Bits 5 to 1 are always read as 1
- Bit0 is the AD conversion data storage flag <ADRxRF>. When the AD conversion result is stored, the flag is set to 1. When either of the registers (ADREGxH, ADREGxL) is read, the flag is cleared to 0.

Figure 3.11.4 AD Converter Related Registers

# AD Conversion Result Lower Register 2/6

ADREG26L (02A4H)

|             | 7                          | 6                       | 5 | 4 | 3 | 2 | 1 | 0                                                          |
|-------------|----------------------------|-------------------------|---|---|---|---|---|------------------------------------------------------------|
| Bit symbol  | ADR21                      | ADR20                   |   |   |   |   |   | ADR2RF                                                     |
| Read/Write  | F                          | ₹                       |   |   |   |   |   | R                                                          |
| After reset | Unde                       | fined                   |   |   |   |   |   | 0                                                          |
| Function    | Stores lower<br>conversion | 2 bits of AD on result. |   |   |   |   |   | AD conversion data storage flag 1:Conversion result stored |

### AD Conversion Data Upper Register 2/6

ADREG26H (02A5H)

|             | 7     | 6                                            | 5     | 4     | 3     | 2     | 1     | 0     |
|-------------|-------|----------------------------------------------|-------|-------|-------|-------|-------|-------|
| Bit symbol  | ADR29 | ADR28                                        | ADR27 | ADR26 | ADR25 | ADR24 | ADR23 | ADR22 |
| Read/Write  |       | R                                            |       |       |       |       |       |       |
| After reset |       | Undefined                                    |       |       |       |       |       |       |
| Function    |       | Stores upper 8 bits of AD conversion result. |       |       |       |       |       |       |

# AD Conversion Data Lower Register 3/7

ADREG37L (02A6H)

|             | 7     | 6                            | 5 | 4 | 3 | 2 | 1 | 0                                                          |
|-------------|-------|------------------------------|---|---|---|---|---|------------------------------------------------------------|
| Bit symbol  | ADR31 | ADR30                        |   |   |   |   |   | ADR3RF                                                     |
| Read/Write  | F     | ₹                            |   |   |   |   |   | R                                                          |
| After reset | Unde  | efined                       |   |   |   |   |   | 0                                                          |
| Function    |       | · 2 bits of AD<br>on result. |   |   |   |   |   | AD conversion data storage flag 1:Conversion result stored |

# AD Conversion Result Upper Register 3/7

ADREG37H (02A7H)

|             | 7                                            | 6         | 5     | 4     | 3     | 2     | 1     | 0     |
|-------------|----------------------------------------------|-----------|-------|-------|-------|-------|-------|-------|
| Bit symbol  | ADR39                                        | ADR38     | ADR37 | ADR36 | ADR35 | ADR34 | ADR33 | ADR32 |
| Read/Write  |                                              | R         |       |       |       |       |       |       |
| After reset |                                              | Undefined |       |       |       |       |       |       |
| Function    | Stores upper 8 bits of AD conversion result. |           |       |       |       |       |       |       |

Channel x conversion result



- Bits 5 to1 are always read as 1.
- Bit0 is the AD conversion data storage flag <ADRxRF>. When the AD conversion result is stored, the flag is set to 1. When either of the registers (ADREGxH, ADREGxL) is read, the flag is cleared to 0.

Figure 3.11.5 AD Converter Related Registers

# 3.11.2 Description of Operation

# (1) Analog reference voltage

A high-level analog reference voltage is applied to the VREFH pin; a low-level analog reference voltage is applied to the VREFL pin. To perform AD conversion, the reference voltage, the difference between VREFH and VREFL, is divided by 1024 using string resistance. The result of the division is then compared with the analog input voltage.

To turn off the switch between VREFH and VREFL, write a 0 to ADMOD1<VREFON> in AD mode control register 1. To start AD conversion in the OFF state, first write a 1 to ADMOD1<VREFON>, wait 3  $\mu$ s until the internal reference voltage stabilizes (This is not related to fc), then set ADMOD0<ADS> to 1.

# (2) Analog input channel selection

The analog input channel selection varies depends on the operation mode of the AD converter.

- In analog input channel fixed mode (ADMOD0<SCAN> = 0)
  Setting ADMOD1<ADCH2:0> selects one of the input pins AN0 to AN7 as the input channel.
- In analog input channel scan mode (ADMOD0<SCAN> = 1)
   Setting ADMOD1<ADCH2:0> selects one of the eight scan modes.

Table 3.11.1 illustrates analog input channel selection in each operation mode.

On a reset, ADMOD0<SCAN> is set to 0 and ADMOD1<ADCH2:0> is initialized to 000. Thus pin AN0 is selected as the fixed input channel. Pins not used as analog input channels can be used as standard input port pins.

| <adch2:0></adch2:0> | Channel Fixed<br><scan> = 0</scan> | Channel Scan<br><scan> = 1</scan>     |
|---------------------|------------------------------------|---------------------------------------|
| 000                 | AN0                                | AN0                                   |
| 001                 | AN1                                | AN0 → AN1                             |
| 010                 | AN2                                | $AN0 \rightarrow AN1 \rightarrow AN2$ |
| 011                 | AN3                                | $AN0 \to AN1 \to AN2 \to AN3$         |
| 100                 | AN4                                | AN4                                   |
| 101                 | AN5                                | AN4 → AN5                             |
| 110                 | AN6                                | $AN4 \rightarrow AN5 \rightarrow AN6$ |
| 111                 | AN7                                | $AN4 \to AN5 \to AN6 \to AN7$         |

Table 3.11.1 Analog Input Channel Selection

### (3) Starting AD conversion

To start AD conversion, write a 1 to ADMOD0<ADS> in AD mode control register 0 or ADMOD1<ADTRGE> in AD mode control register 1, and input falling edge on  $\overline{\text{ADTRG}}$  pin. When AD conversion starts, the AD conversion busy flag ADMOD0<ADBF> will be set to 1, indicating that AD conversion is in progress.

Writing a 1 to ADMOD0<ADS> during AD conversion restarts conversion. At that time, to determine whether the AD conversion results have been preserved, check the value of the conversion data storage flag AD REGxL<ADRxRF>.

During AD conversion, a falling edge input on the ADTRG pin will be ignored.

#### (4) AD conversion modes and the AD conversion end interrupt

The four AD conversion modes are:

- Channel fixed single conversion mode
- Channel scan single conversion mode
- Channel fixed repeat conversion mode
- Channel scan repeat conversion mode

The ADMOD0<REPEAT> and ADMOD0<SCAN> settings in AD mode control register 0 determine the AD mode setting.

Completion of AD conversion triggers an INTAD AD conversion end interrupt request. Also, ADMOD0<EOCF> will be set to 1 to indicate that AD conversion has been completed.

# a. Channel fixed single conversion mode

Setting ADMOD0<REPEAT> and ADMOD0<SCAN> to 00 selects conversion channel fixed single conversion mode.

In this mode data on one specified channel is converted once only. When the conversion has been completed, the ADMOD0<EOCF> flag is set to 1, ADMOD0<ADBF> is cleared to 0, and an INTAD interrupt request is generated.

#### b. Channel scan single conversion mode

Setting ADMOD0<REPEAT> and ADMOD0<SCAN> to 01 selects conversion channel scan single conversion mode.

In this mode data on the specified scan channels is converted once only. When scan conversion has been completed, ADMOD0<EOCF> is set to 1, ADMOD0<ADBF> is cleared to 0, and an INTAD interrupt request is generated.

#### Channel fixed repeat conversion mode

Setting ADMOD0<REPEAT> and ADMOD0<SCAN> to 10 selects conversion channel fixed repeat conversion mode.

In this mode data on one specified channel is converted repeatedly. When conversion has been completed, ADMOD0<EOCF> is set to 1 and ADMOD0<ADBF> is not cleared to 0 but held at 1. INTAD interrupt request generation timing is determined by the setting of ADMOD0<ITM0>.

Setting <ITM0> to 0 generates an interrupt request every time an AD conversion is completed.

Setting <ITM0> to 1 generates an interrupt request on completion of every fourth conversion.

# Channel scan repeat conversion mode

Setting ADMOD0<REPEAT> and ADMOD0<SCAN> to 11 selects conversion channel scan repeat conversion mode.

In this mode data on the specified scan channels is converted repeatedly. When each scan conversion has been completed, ADMODO<EOCF> is set to 1 and an INTAD interrupt request is generated. ADMODO<ADBF> is not cleared to 0 but held at 1.

To stop conversion in a repeat conversion mode (e.g., in cases c and d), write a 0 to ADMODO<REPEAT>. After the current conversion has been completed, the repeat conversion mode terminates and ADMOD0<ADBF> is cleared to 0.

Switching to a halt state (IDLE2 mode with ADMOD1<I2AD> cleared to 0, IDLE1 mode or STOP mode) immediately stops operation of the AD converter even when AD conversion is still in progress. In repeat conversion modes (e.g., in cases c and d), when the halt is released, conversion restarts from the beginning. In single conversion modes (e.g., in cases a and b), conversion does not restart when the halt is released (The converter remains stopped).

Table 3.11.2 shows the relationship between the AD conversion modes and interrupt requests.

Х

1

| Mode                                 | Interrupt Request<br>Generation     | ADMOD0        |                   |               |
|--------------------------------------|-------------------------------------|---------------|-------------------|---------------|
|                                      |                                     | <itm0></itm0> | <repeat></repeat> | <scan></scan> |
| Channel fixed single conversion mode | After completion of conversion      | Х             | 0                 | 0             |
| Channel scan single conversion mode  | After completion of scan conversion | Х             | 0                 | 1             |
| Channel fixed repeat conversion mode | Every conversion                    | 0             | - 1               | 0             |
|                                      | Every forth conversion              | 1             |                   |               |
| Channel scan repeat                  | After completion of                 | <b>V</b>      | 1                 | 1             |

every scan conversion

Table 3.11.2 Relationship between AD Conversion Modes and Interrupt Requests

X: Don't care

conversion mode

#### (5) AD conversion time

 $84 \text{ states } (4.7 \text{ } \mu \text{s} \text{ at fFPH} = 36 \text{ MHz})$  are required for the AD conversion of one channel.

#### (6) Storing and reading the results of AD conversion

The AD conversion data upper and lower registers (ADREG04H/L to ADREG37H/L) store the results of AD conversion. (ADREG04H/L to ADREG37H/L are read-only registers.)

In channel fixed repeat conversion mode, the conversion results are stored successively in registers ADREG04H/L to ADREG37H/L. In other modes the AN0 and AN4, AN1 and AN5, AN2 and AN6, and AN3 and AN7 conversion results are stored in ADREG04H/L, ADREG15H/L, ADREG26H/L and ADREG37H/L respectively.

Table 3.11.3 shows the correspondence between the analog input channels and the registers, which are used to hold the results of AD conversion.

Table 3.11.3 Correspondence between Analog Input Channels and AD Conversion Result Registers

|                                  | AD Conversion Result Register           |                                                               |  |
|----------------------------------|-----------------------------------------|---------------------------------------------------------------|--|
| Analog Input Channel<br>(Port 8) | Conversion Modes<br>Other than at Right | Channel Fixed Repeat<br>Conversion Mode<br>( <itm0>=1)</itm0> |  |
| AN0                              | ADREG04H/L                              |                                                               |  |
| AN1                              | ADREG15H/L                              | ADREG04H/L ←                                                  |  |
| AN2                              | ADREG26H/L                              | ADDE04511/I                                                   |  |
| AN3                              | ADREG37H/L                              | ADREG15H/L                                                    |  |
| AN4                              | ADREG04H/L                              | ¥<br>ADREG26H/L                                               |  |
| AN5                              | ADREG15H/L                              |                                                               |  |
| AN6                              | ADREG26H/L                              | ADREG37H/L                                                    |  |
| AN7                              | ADREG37H/L                              |                                                               |  |

<ADRxRF> bit0 of the AD conversion data lower register is used as the AD conversion data storage flag. The storage flag indicates whether the AD conversion result register has been read or not. When a conversion result is stored in the AD conversion result register, the flag is set to 1. When either of the AD conversion result registers (ADREGxH or ADREGxL) is read, the flag is cleared to 0.

Reading the AD conversion result also clears the AD conversion end flag ADMOD0<EOCF> to 0.

# Setting example:

a. Convert the analog input voltage on the AN3 pin and write the result, to memory address 1000H using the AD interrupt (INTAD) processing routine.

#### Main routine:

```
7 6 5 4 3 2 1 0
INTE0AD ← X 1 0 0 - - - -
                                         Enable INTAD and set it to interrupt level 4.
ADMOD1 \leftarrow 1 1 X X 0 0 1 1
                                         Set pin AN3 to be the analog input channel.
ADMOD0 \leftarrow X X 0 0 0 0 0 1
                                         Start conversion in channel fixed single conversion mode.
Interrupt routine processing example:
WA
            ← ADREG37
                                         Read value of ADREG37L and ADREG37H into 16-bit
                                         general-purpose register WA.
WA
           > > 6
                                         Shift contents read into WA six times to right and zero-fill upper
(1000H)
            \leftarrow WA
                                         Write contents of WA to memory address 1000H.
```

b. This example repeatedly converts the analog input voltages on the three pins ANO, AN1 and AN2, using channel scan repeat conversion mode.

X: Don't care, -: No change

# 3.12 Watchdog Timer (Runaway detection timer)

The TMP91C820A features a watchdog timer for detecting runaway.

The watchdog timer (WDT) is used to return the CPU to normal state when it detects that the CPU has started to malfunction (Runaway) due to causes such as noise. When the watchdog timer detects a malfunction, it generates a non-maskable interrupt INTWD to notify the CPU of the malfunction.

Connecting the watchdog timer output to the reset pin internally forces a reset. (The level of external RESET pin is not changed.)

# 3.12.1 Configuration

Figure 3.12.1 is a block diagram of he watchdog timer (WDT).



Figure 3.12.1 Block Diagram of Watchdog Timer

Note: The watchdog timer cannot operate by disturbance noise in some case.

Take care when design the device.

The watchdog timer consists of a 22-stage binary counter which uses the system clock (fsys) as the input clock. The binary counter can output fsys/2<sup>15</sup>, fsys/2<sup>17</sup>, fsys/2<sup>19</sup> and fsys/2<sup>21</sup>.



Figure 3.12.2 Normal Mode

The runaway is detected when an overflow occurs, and the watchdog timer can reset device. In this case, the reset time will be between 22 and 29 states (19.6 to 25.8  $\mu$ s at fFPH = 36MHz, fosch = 2.25 state) is fFPH/2, where fFPH is generated by dividing the high-speed oscillator clock (fosch) by sixteen through the clock gear function.



Figure 3.12.3 Reset Mode

#### 3.12.2 Control Registers

The watchdog timer WDT is controlled by two controls registers WDMOD and WDCR.

- (1) Watchdog timer mode register (WDMOD)
  - a. Setting the detection time for the watchdog timer in <WDTP>

This 2-bit register is used for setting the watchdog timer interrupt time used when detecting runaway. On a reset this register is initialized to WDMOD<WDTP1:0> = 00.

The detection times for WDT are shown in Figure 3.12.4.

b. Watchdog timer enable/disable control register <WDTE>

On a reset WDMOD<WDTE> is initialized to 1, enabling the watchdog timer.

To disable the watchdog timer, it is necessary to set this bit to 0 and to write the disable code (B1H) to the watchdog timer control register (WDCR). This makes it difficult for the watchdog timer to be disabled by runaway.

However, it is possible to return the watchdog timer from the disabled state to the enabled state merely by setting <WDTE> to 1.

c. Watchdog timer out reset connection <RESCR>

This register is used to connect the output of the watchdog timer with the RESET terminal internally. Since WDMOD<RESCR>is initialized to 0 on a reset, a reset by the watchdog timer will not be performed.

(2) Watchdog timer control register (WDCR)

This register is used to disable and clear the binary counter for the watchdog timer.

Disable control the watchdog timer can be disabled by clearing WDMOD<WDTE> to 0 and then writing the disable code (B1H) to the WDCR register.

```
WDMOD \leftarrow 0 - - - - - 0 Clear WDMOD<WDTE> to 0. WDCR \leftarrow 1 0 1 1 0 0 0 1 Write the disable code (B1H).
```

• Enable control

Set WDMOD<WDTE> to 1.

Watchdog timer clear control

To clear the binary counter and cause counting to resume, write the clear code (4EH) to the WDCR register.

```
WDCR \leftarrow 0 1 0 0 1 1 1 0 Write the clear code (4EH).
```

Note1: If it is used disable control, set the disable code (B1H) to WDCR after write the clear code (4EH) once. (Please refer to setting example.)

Note2: If it is changed Watchdog timer setting, change setting after set to disable condition once.



Figure 3.12.4 Watchdog Timer Mode Register



Figure 3.12.5 Watchdog Timer Control Register

#### 3.12.3 Operation

The watchdog timer generates an INTWD interrupt when the detection time set in the WDMOD<BC with the WDMOD word interrupt will be generated. If the CPU malfunctions (e.g., if runaway occurs) due to causes such as noise, but does not execute the instruction used to clear the binary counter, the binary counter will overflow and an INTWD interrupt will be generated. The CPU will detect malfunction (Runaway) due to the INTWD interrupt and in this case it is possible to return to the CPU to normal operation by means of an anti-multifunction program.

The watchdog timer does not operate in IDLE1 or STOP mode, as the binary counter continues counting during bus release (when  $\overline{\text{BUSAK}}$  goes low).

When the device is in IDLE2 mode, the operation of WDT depends on the WDMOD<I2WDT> setting. Ensure that WDMOD<I2WDT> is set before the device enters IDLE2 mode.

Example: a. Clear the binary counter.

```
WDCR \leftarrow 0 1 0 0 1 1 1 0 Write the clear code (4EH).
```

b. Set the watchdog timer detection time to  $2^{17}/f_{SYS}$ .

```
WDMOD \leftarrow 1 0 1 - - - 0
```

c. Disable the watchdog timer.

### 3.13 Real Time Clock (RTC)

#### 3.13.1 Function Description for RTC

- 1) Clock function (Hour, minute, second)
- 2) Calendar function (Month and day, day of the week, and leap year)
- 3) 24- or 12-hour (AM/PM) clock function
- 4) +/- 30 second adjustment function (by software)
- 5) Alarm output 1Hz/16Hz (from ALARM pin)
- 6) Interrupt generate by Alarm output 1Hz/16Hz

### 3.13.2 Block Diagram



Figure 3.13.1 RTC Block Diagram

### Note 1: The Christian era year column:

This product has year column toward only lower two columns. Therefore the next year in 99 works as 00 years. In system to use it, please manage upper two columns with the system side when handle year column in the christian era.

#### Note 2: Leap year:

A leap year is the year, which is divisible with 4, but the year, which there is exception, and is divisible with 100, is not a leap year. However, the year is divisible with 400, is a leap year. But there is not this product for the correspondence to the above exception. Because there are only with the year which is divisible with 4 as a leap year, please cope with the system side if this function is problem.

# 3.13.3 Control Registers

Table 3.13.1 PAGE 0 (Clock function) Registers

| Symbol | Address | Bit7                | Bit6           | Bit5           | Bit4                | Bit3            | Bit2            | Bit1      | Bit0         | Function                           | Read/Write |
|--------|---------|---------------------|----------------|----------------|---------------------|-----------------|-----------------|-----------|--------------|------------------------------------|------------|
| SECR   | 0320H   |                     | 40 s           | 20 s           | 10 s                | 8 s             | 4 s             | 2 s       | 1 s          | Second column                      | R/W        |
| MINR   | 0321H   |                     | 40 min.        | 20 min.        | 10 min.             | 8 min.          | 4 min.          | 2 min.    | 1 min.       | Minute column                      | R/W        |
| HOURR  | 0322H   |                     |                | 20<br>/PM/AM   | 10 hours            | 8<br>hours      | 4 hours         | 2 hours   | 1 hour       | Hour column                        | R/W        |
| DAYR   | 0323H   |                     |                |                |                     |                 | W2              | W1        | WO           | Day of the week column             | R/W        |
| DATER  | 0324H   |                     |                | Day 20         | Day 10              | Day 8           | Day 4           | Day 2     | Day 1        | Day column                         | R/W        |
| MONTHR | 0325H   |                     |                |                | Oct.                | Aug.            | Apr.            | Feb.      | Jan.         | Month column                       | R/W        |
| YEARR  | 0326H   | Year 80             | Year 40        | Year 20        | Year 10             | Year 8          | Year 4          | Year 2    | Year 1       | Year column<br>(Lower two columns) | R/W        |
| PAGER  | 0327H   | Interrupt<br>enable |                |                | Adjustment function | Clock<br>enable | Alarm<br>enable |           | PAGE setting | PAGE register                      | W, R/W     |
| RESTR  | 0328H   | 1HZ<br>enable       | 16HZ<br>enable | Clock<br>reset | Alarm reset         |                 | Always          | write "0" |              | Reset register                     | Write only |

Note: As for SECR, MINR, HOURR, DAYR, MONTHR, YEARR of PAGE0, current state is read when read it.

Table 3.13.2 PAGE 1 (Alarm function) Registers

|        |         |                     |                |                |             | •               |                 |           |              |                                  |            |
|--------|---------|---------------------|----------------|----------------|-------------|-----------------|-----------------|-----------|--------------|----------------------------------|------------|
| Symbol | Address | Bit7                | Bit6           | Bit5           | Bit4        | Bit3            | Bit2            | Bit1      | Bit0         | Function                         | Read/Write |
| SECR   | 0320H   |                     |                |                |             |                 |                 |           |              |                                  | R/W        |
| MINR   | 0321H   |                     | 40 min.        | 20 min.        | 10 min.     | 8 min.          | 4 min.          | 2 min.    | 1 min.       | Minute column for alarm          | R/W        |
| HOURR  | 0322H   |                     |                | 20<br>/PM/AM   | 10 hours    | 8 hours         | 4 hours         | 2 hours   | 1 hour       | Hour column for alarm            | R/W        |
| DAYR   | 0323H   |                     |                |                |             |                 | W2              | W1        | Wo           | Day of the week column for alarm | R/W        |
| DATER  | 0324H   |                     |                | Day 20         | Day 10      | Day 8           | Day 4           | Day 2     | Day 1        | Day column for<br>alarm          | R/W        |
| MONTHR | 0325H   |                     |                |                |             |                 |                 |           | 24/12        | 24-hour clock<br>mode            | R/W        |
| YEARR  | 0326H   |                     |                |                |             |                 |                 | Leap-yea  | ar setting   | Leap-year mode                   | R/W        |
| PAGER  | 0327H   | Interrupt<br>enable |                |                |             | Clock<br>enable | Alarm<br>enable |           | PAGE setting | PAGE register                    | W, R/W     |
| RESTR  | 0328H   | 1HZ<br>enable       | 16HZ<br>enable | Clock<br>reset | Alarm reset |                 | Always          | write "0" |              | Reset register                   | Write only |

Note2: As for SECR, MINR, HOURR, DAYR, MONTHR, YEARR of PAGE1, current state is read when read it

# 3.13.4 Detailed Explanation of Control Register

RTC is not initialized by reset.

Therefore, all registers must be initialized at the beginning of the program.

## (1) Second column register (for PAGE0 only)

SECR (0320H)

|             | 7            | 6                 | 5                 | 4                 | 3                | 2                | 1                | 0                |  |  |  |  |
|-------------|--------------|-------------------|-------------------|-------------------|------------------|------------------|------------------|------------------|--|--|--|--|
| Bit symbol  |              | SE6               | SE5               | SE4               | SE3              | SE2              | SE1              | SE0              |  |  |  |  |
| Read/Write  |              |                   | R/W               |                   |                  |                  |                  |                  |  |  |  |  |
| After reset |              |                   | Undefined         |                   |                  |                  |                  |                  |  |  |  |  |
| Function    | "0" is read. | 40 sec.<br>column | 20 sec.<br>column | 10 sec.<br>column | 8 sec.<br>column | 4 sec.<br>column | 2 sec.<br>column | 1 sec.<br>column |  |  |  |  |

| 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 s  |
|----|---|---|---|---|---|---|------|
| 0  | 0 | 0 | 0 | 0 | 0 | 1 | 1 s  |
| 0  | 0 | 0 | 0 | 0 | 1 | 0 | 2 s  |
| 0  | 0 | 0 | 0 | 0 | 1 | 1 | 3 s  |
| 0  | 0 | 0 | 0 | 1 | 0 | 0 | 4 s  |
| 0  | 0 | 0 | 0 | 1 | 0 | 1 | 5 s  |
| 0  | 0 | 0 | 0 | 1 | 1 | 0 | 6 s  |
| 0  | 0 | 0 | 0 | 1 | 1 | 1 | 7 s  |
| 0  | 0 | 0 | 1 | 0 | 0 | 0 | 8 s  |
| 0  | 0 | 0 | 1 | 0 | 0 | 1 | 9 s  |
| 0  | 0 | 1 | 0 | 0 | 0 | 0 | 10 s |
|    |   |   |   | : |   |   |      |
| 0  | 0 | 1 | 1 | 0 | 0 | 1 | 19 s |
| 0  | 1 | 0 | 0 | 0 | 0 | 0 | 20 s |
|    |   |   |   | : |   |   |      |
| 0  | 1 | 0 | 1 | 0 | 0 | 1 | 29 s |
| 0  | 1 | 1 | 0 | 0 | 0 | 0 | 30 s |
|    |   |   |   | : |   |   |      |
| 0  | 1 | 1 | 1 | 0 | 0 | 1 | 39 s |
| 1  | 0 | 0 | 0 | 0 | 0 | 0 | 40 s |
|    |   |   |   | : |   |   |      |
| 1  | 0 | 0 | 1 | 0 | 0 | 1 | 49 s |
| 1  | 0 | 1 | 0 | 0 | 0 | 0 | 50 s |
| E- |   |   |   | : |   |   |      |
| 1  | 0 | 1 | 1 | 0 | 0 | 1 | 59 s |
|    |   |   |   |   |   |   | -    |

Note: Do not set the data other than showing above.

# (2) Minute column register (for PAGE0/1)

MINR (0321H)

|             | 7            | 6                 | 5                 | 4                 | 3                | 2                | 1                | 0                |  |  |  |  |
|-------------|--------------|-------------------|-------------------|-------------------|------------------|------------------|------------------|------------------|--|--|--|--|
| Bit symbol  |              | MI6               | MI5               | MI4               | MI3              | MI2              | MI1              | MIO              |  |  |  |  |
| Read/Write  |              |                   | R/W               |                   |                  |                  |                  |                  |  |  |  |  |
| After reset |              |                   |                   |                   | Undefined        |                  |                  |                  |  |  |  |  |
| Function    | "0" is read. | 40 min,<br>column | 20 min,<br>column | 10 min,<br>column | 8 min,<br>column | 4 min,<br>column | 2 min,<br>column | 1 min,<br>column |  |  |  |  |

| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 min.   |
|---|---|---|---|---|---|---|----------|
| 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 min.   |
| 0 | 0 | 0 | 0 | 0 | 1 | 0 | 2 min.   |
| 0 | 0 | 0 | 0 | 0 | 1 | 1 | 3 min.   |
| 0 | 0 | 0 | 0 | 1 | 0 | 0 | 4 min.   |
| 0 | 0 | 0 | 0 | 1 | 0 | 1 | 5 min.   |
| 0 | 0 | 0 | 0 | 1 | 1 | 0 | 6 min.   |
| 0 | 0 | 0 | 0 | 1 | 1 | 1 | 7 min.   |
| 0 | 0 | 0 | 1 | 0 | 0 | 0 | 8 min.   |
| 0 | 0 | 0 | 1 | 0 | 0 | 1 | 9 min.   |
| 0 | 0 | 1 | 0 | 0 | 0 | 0 | 10 min.  |
|   |   |   |   | : |   |   |          |
| 0 | 0 | 1 | 1 | 0 | 0 | 1 | 19 min.  |
| 0 | 1 | 0 | 0 | 0 | 0 | 0 | 20 min.  |
|   |   |   |   | : |   |   |          |
| 0 | 1 | 0 | 1 | 0 | 0 | 1 | 29 min.  |
| 0 | 1 | 1 | 0 | 0 | 0 | 0 | 30 min.  |
|   |   |   |   | : |   |   |          |
| 0 | 1 | 1 | 1 | 0 | 0 | 1 | 39 min.  |
| 1 | 0 | 0 | 0 | 0 | 0 | 0 | 40 min.  |
|   |   |   |   | : |   |   |          |
| 1 | 0 | 0 | 1 | 0 | 0 | 1 | 49 min.  |
| 1 | 0 | 1 | 0 | 0 | 0 | 0 | 50 min.  |
|   |   |   |   | : |   |   | <u>.</u> |
| 1 | 0 | 1 | 1 | 0 | 0 | 1 | 59 min.  |
|   |   | _ | _ | _ | _ | _ |          |

Note: Do not set the data other than showing above.

23 o'clock

## (3) Hour column register (for PAGE0/1)

a. In case of 24-hour clock mode (MONTHR<MO0> = 1)

HOURR (0322H)

|             | 7      | 6     | 5                 | 4         |   |   | 3           | 2   | 1             | 0             |  |  |
|-------------|--------|-------|-------------------|-----------|---|---|-------------|-----|---------------|---------------|--|--|
| Bit symbol  |        |       | HO5               | НО        | 4 | Н | О3          | HO2 | HO1           | HO0           |  |  |
| Read/Write  |        |       |                   | R/W       |   |   |             |     |               |               |  |  |
| After reset |        |       |                   | Undefined |   |   |             |     |               |               |  |  |
| Function    | "0" is | read. | 20 hour<br>column | 10 ho     |   |   | hour 4 hour |     | 2 hour column | 1 hour column |  |  |
|             |        |       |                   |           |   |   |             |     |               |               |  |  |
|             |        |       | 0                 | 0         | ( | ) | 0           | 0   | 0             | 0 o'clock     |  |  |
|             |        |       | 0                 | 0         | ( | ) | 0           | 0   | 1             | 1 o'clock     |  |  |
|             |        |       | 0                 | 0         | ( | 0 | 0           | 1   | 0             | 2 o'clock     |  |  |
|             |        |       |                   |           |   | : |             |     |               |               |  |  |
|             |        |       | 0                 | 0         | , | 1 | 0           | 0   | 0             | 8 o'clock     |  |  |
|             |        |       | 0                 | 0         | , | 1 | 0           | 0   | 1             | 9 o'clock     |  |  |
|             |        |       | 0                 | 1         | ( | 0 | 0           | 0   | 0             | 10 o'clock    |  |  |
|             |        |       | <u> </u>          |           |   |   |             |     |               |               |  |  |
|             |        |       | 0                 | 1         | 1 |   | 0           | 0   | 1             | 19 o'clock    |  |  |
|             |        |       | 1                 | 0         | ( | ) | 0           | 0   | 0             | 20 o'clock    |  |  |

Note: Do not set the data other than showing above.

b. In case of 12-hour clock mode (MONTHR<MO0> = 0)

HOURR (0322H)

|             | 1            | U | 9     |                |   | 3                |   | _   |                  | U                 |  |  |  |
|-------------|--------------|---|-------|----------------|---|------------------|---|-----|------------------|-------------------|--|--|--|
| Bit symbol  |              |   | HO5   | НО             | 4 | НО3              |   | HO2 | HO1              | HO0               |  |  |  |
| Read/Write  |              |   |       | R/W            |   |                  |   |     |                  |                   |  |  |  |
| After reset |              |   |       | Undefined      |   |                  |   |     |                  |                   |  |  |  |
| Function    | "0" is read. |   | PM/AM | 10 ho<br>colur |   | 8 hour<br>column |   |     | 2 hour<br>column | 1 hour column     |  |  |  |
|             |              |   |       |                |   |                  |   |     |                  |                   |  |  |  |
|             |              |   | 0     | 0              | 0 | 0                | ) | 0   | 0                | 0 o'clock<br>(AM) |  |  |  |
|             |              |   | 0     | 0              | 0 | 0                | ) | 0   | 1                | 1 o'clock         |  |  |  |
|             |              |   | 0     | 0              | 0 | 0                | ) | 1   | 0                | 2 o'clock         |  |  |  |
|             |              |   |       |                |   | :                |   |     |                  |                   |  |  |  |
|             |              |   | 0     | 0              | 1 | 0                | ) | 0   | 1                | 9 o'clock         |  |  |  |
|             |              |   | 0     | 1              | 0 | 0                | ) | 0   | 0                | 10 o'clock        |  |  |  |
|             |              |   | 0     | 1              | 0 | 0                |   | 0   | 1                | 11 o'clock        |  |  |  |

Note: Do not set the data other than showing above.

0

0

0

0

0

1

0 o'clock (PM)

1 o'clock

0

1

## (4) Day of the week column register (for PAGE0/1)

DAYR (0323H)

|             | 7 | 6 | 5            | 4  | 3         | 2   | 1   | 0   |
|-------------|---|---|--------------|----|-----------|-----|-----|-----|
| Bit symbol  |   |   |              |    |           | WE2 | WE1 | WE0 |
| Read/Write  |   |   |              |    |           |     | R/W |     |
| After reset |   |   |              |    | Undefined |     |     |     |
| Function    |   |   | "0" is read. | W2 | W1        | W0  |     |     |

| 0 | 0 | 0 | Sunday    |
|---|---|---|-----------|
| 0 | 0 | 1 | Monday    |
| 0 | 1 | 0 | Tuesday   |
| 0 | 1 | 1 | Wednesday |
| 1 | 0 | 0 | Thursday  |
| 1 | 0 | 1 | Friday    |
| 1 | 1 | 0 | Saturday  |

Note: Do not set the data other than showing above.

## (5) Day column register (for PAGE0/1)

DATER (0324H)

|             | 7      | 6     | 5         | 4   |    | 3     |   | 2     | 1     | 0        |
|-------------|--------|-------|-----------|-----|----|-------|---|-------|-------|----------|
| Bit symbol  |        |       | DA5 DA4   |     | 4  | DA3   | 3 | DA2   | DA1   | DA0      |
| Read/Write  |        |       | R/W       |     |    |       |   |       |       |          |
| After reset |        |       | Undefined |     |    |       |   |       |       |          |
| Function    | "0" is | read. | Day 20    | Day | 10 | Day 8 | 8 | Day 4 | Day 2 | Day 1    |
|             |        | -     |           |     |    |       |   |       |       |          |
|             |        |       | 0         | 0   | 0  |       | 0 | 0     | 0     | 0        |
|             |        |       | 0         | 0   | 0  |       | 0 | 0     | 1     | 1st day  |
|             |        |       | 0         | 0   | 0  |       | 0 | 1     | 0     | 2nd day  |
|             |        |       | 0         | 0   | 0  |       | 0 | 1     | 1     | 3rd day  |
|             |        |       | 0         | 0   | 0  |       | 1 | 0     | 0     | 4th day  |
|             |        |       |           |     |    | :     |   |       |       |          |
|             |        |       | 0         | 0   | 1  |       | 0 | 0     | 1     | 9th day  |
|             |        |       | 0         | 1   | 0  |       | 0 | 0     | 0     | 10th day |
|             |        |       | 0         | 1   | 0  |       | 0 | 0     | 1     | 11th day |
|             |        |       |           |     |    | :     |   |       |       |          |
|             |        |       | 0         | 1   | 1  |       | 0 | 0     | 1     | 19th day |
|             |        |       | 1         | 0   | 0  |       | 0 | 0     | 0     | 20th day |
|             |        |       |           |     | 1  | :     |   |       |       |          |
|             |        |       | 1         | 0   | 1  |       | 0 | 0     | 1     | 29th day |
|             |        |       | 1         | 1   | 0  |       | 0 | 0     | 0     | 30th day |
|             |        |       | 1         | 1   | 0  |       | 0 | 0     | 1     | 31st day |

Note1: Do not set the data other than showing above.

Note2: Do not set the day which is not existed. (ex: 30<sup>th</sup> Feb)

## (6) Month column register (for PAGE0 only)

MONTHR (0325H)

|             | 7 | 6            | 5 | 4         | 3        | 2         | 1        | 0       |
|-------------|---|--------------|---|-----------|----------|-----------|----------|---------|
| Bit symbol  |   |              |   | MO4       | MO4      | MO2       | MO1      | MO0     |
| Read/Write  |   |              |   |           |          | R/W       |          |         |
| After reset |   |              |   |           |          | Undefined |          |         |
| Function    |   | "0" is read. |   | 10 months | 8 months | 4 months  | 2 months | 1 month |

| 0 | 0 | 0 | 0 | 1 | January   |
|---|---|---|---|---|-----------|
| 0 | 0 | 0 | 1 | 0 | February  |
| 0 | 0 | 0 | 1 | 1 | March     |
| 0 | 0 | 1 | 0 | 0 | April     |
| 0 | 0 | 1 | 0 | 1 | May       |
| 0 | 0 | 1 | 1 | 0 | June      |
| 0 | 0 | 1 | 1 | 1 | July      |
| 0 | 1 | 0 | 0 | 0 | August    |
| 0 | 1 | 0 | 0 | 1 | September |
| 1 | 0 | 0 | 0 | 0 | October   |
| 1 | 0 | 0 | 0 | 1 | November  |
| 1 | 0 | 0 | 1 | 0 | December  |

Note: Do not set the data other than showing above.

# (7) Select 24-hour clock or 12-hour clock (for PAGE1 only)

MONTHR (0325H)

|             | 7 | 6 | 5 | 4            | 3 | 2 | 1 | 0          |
|-------------|---|---|---|--------------|---|---|---|------------|
| Bit symbol  |   |   |   |              |   |   |   | MO0        |
| Read/Write  |   |   |   |              |   |   |   | R/W        |
| After reset |   |   |   |              |   |   |   | Undefined  |
| Function    |   |   |   | "0" is read. |   |   |   | 1: 24-hour |
|             |   |   |   | o is read.   |   |   |   | 0: 12-hour |

## (8) Year column register (for PAGE0 only)

YEARR (0326H)

|             | 7        | 6         | 5        | 4        | 3       | 2       | 1       | 0      |
|-------------|----------|-----------|----------|----------|---------|---------|---------|--------|
| Bit symbol  | YE7      | YE6       | YE5      | YE4      | YE3     | YE2     | YE1     | YE0    |
| Read/Write  |          | R/W       |          |          |         |         |         |        |
| After reset |          | Undefined |          |          |         |         |         |        |
| Function    | 80 Years | 40 Years  | 20 Years | 10 Years | 8 Years | 4 Years | 2 Years | 1 Year |

| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 00 years |  |
|---|---|---|---|---|---|---|---|----------|--|
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 01 years |  |
| 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 02 years |  |
| 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 03 years |  |
| 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 04 years |  |
| 0 | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 05 years |  |
|   |   |   |   |   |   |   |   |          |  |
| 1 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 99 years |  |

Note: Do not set the data other than showing above.

# (9) Leap-year register (for PAGE1 only)

YEARR (0326H)

|    |             | 7 | 6 | 5      | 4     | 3 | 2                  | 1          | 0          |  |
|----|-------------|---|---|--------|-------|---|--------------------|------------|------------|--|
| ₹  | Bit symbol  |   |   |        |       |   |                    | LEAP1      | LEAP0      |  |
| l) | Read/Write  |   |   |        |       |   |                    | R/         | W          |  |
|    | After reset |   |   |        |       |   |                    | Unde       | fined      |  |
|    | Function    |   |   |        |       |   |                    | 00: Leap-y | /ear       |  |
|    |             |   |   |        |       |   | 01: One year after |            |            |  |
|    |             |   |   |        |       |   |                    | leap ye    | ear        |  |
|    |             |   |   | "0" is | read. |   |                    | 10: Two ye | ears after |  |
|    |             |   |   |        |       |   |                    | leap ye    |            |  |
|    |             |   |   |        |       |   |                    | 11: Three  |            |  |
|    |             |   |   |        |       |   |                    | after le   | eap year   |  |

| 0 | 0 | Current year is leap year              |
|---|---|----------------------------------------|
| 0 | 1 | Present is next year of a leap year    |
| 1 | 0 | Present is two years after a leap year |
| 1 | 1 | Present is three years after leap year |

### (10) Setting PAGE register (for PAGE0/1)

PAGER (0327H) Read-modify write instruction are prohibited

|          |             | 7          | 6      | 5     | 4            | 3          | 2          | 1            | 0         |
|----------|-------------|------------|--------|-------|--------------|------------|------------|--------------|-----------|
|          | Bit symbol  | INTENA     |        |       | ADJUST       | ENATMR     | ENAALM     |              | PAGE      |
|          | Read/Write  | R/W        |        |       | W            | R          | W          |              | R/W       |
|          | After reset | 0          |        |       | Undefined    | Unde       | efined     |              | Undefined |
|          | Function    | INTRTC     |        |       | 0:Don't care | Clock      | ALARM      | "0" is read. | PAGE      |
| d        |             | 1: Enable  | "0" is | read. | 1:Adjust     | 1: Enable  | 1: Enable  |              | selection |
| <b>—</b> |             | 0: Disable |        |       |              | 0: Disable | 0: Disable |              |           |

Note: Pleas keep the setting order below and don't set same time.

(Set difference time to Clock/Alarm setting and interrupt setting)

(Example) Clock setting/Alarm setting

ld (pager), 0ch : Clock, Alarm enable

ld (pager), 8ch : Interrupt enable

| DAGE | 0 | Select Page0 |
|------|---|--------------|
| FAGE | 1 | Select Page1 |

|        | 0 | Don't care                                                                                                                                                                                                                                                                                                                               |
|--------|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        | 1 | Adjust sec. counter.                                                                                                                                                                                                                                                                                                                     |
| ADJUST |   | When set this bit to "1" the sec. counter become to "0" when the value of sec. counter is $0-29$ . And in case that value of sec. counter is 30-59, min. counter is carried and become sec. counter to "0". Output Adjust signal during 1 cycle of $f_{SYS}$ . After being adjusted once, Adjust is released automatically. (PAGE0 only) |

### (11) Setting reset register (for PAGE0/1)

RESTR (1328H) Read-modify write instruction are prohibited

|   |             | 7          | 6          | 5        | 4           | 3   | 2      | 1         | 0   |
|---|-------------|------------|------------|----------|-------------|-----|--------|-----------|-----|
|   | Bit symbol  | DIS1Hz     | DIS16Hz    | RSTTMR   | RSTALM      | RE3 | RE2    | RE1       | RE0 |
|   | Read/Write  |            | W          |          |             |     |        |           |     |
| , | After reset |            | Undefined  |          |             |     |        |           |     |
|   | Function    | 1Hz        | 16Hz       | 1: Clock | 1:          |     |        |           |     |
| d |             | 0: Enable  | 0: Enable  | reset    | Alarm reset |     | Always | write "0" |     |
| u |             | 1: Disable | 1: Disable |          |             |     |        |           |     |

| RSTALM   | 0 | Unused               |
|----------|---|----------------------|
| KSTALIVI | 1 | Reset alarm register |

Note: When write "1", reset alarm during 1 cycle of f<sub>SYS</sub>. After that, reset is released automatically.

| RSTTMR | 0 | Unused        |
|--------|---|---------------|
| KSTTWK | 1 | Reset divider |

Note: When write "1", reset alarm during 1 cycle of f<sub>SYS</sub>. After that, reset is released automatically.

| <dis1hz></dis1hz> | <dis1hz></dis1hz> | (PAGER)<br><enaalm></enaalm> | Source signal |
|-------------------|-------------------|------------------------------|---------------|
| 1                 | 1                 | 1                            | Alarm         |
| 0                 | 1                 | 0                            | 1Hz           |
| 1                 | 0                 | 0                            | 16Hz          |
|                   | Others            |                              | Output "0"    |

### 3.13.5 Operational Description

### (1) Reading clock data

There is the case, which reads wrong data when carry of the inside counter happens during the operation which clock data reads. Therefore please read two times with the following way for reading correct data.



Figure 3.13.2 Flowchart of Clock Data Read

### (2) Timing of INTRTC and Clock data

When time is read by interrupt, read clock data within 0.5s(s) after generating interrupt. This is because count up of clock data occurs by rising edge of 1Hz pulse cycle.



Figure 3.13.3 Timing of INTRTC and Clock data

#### (3) Writing clock data

When there is carry on the way of write operation, expecting data can not be wrote exactly. Therefore, in order to write in data exactly please follow the below way.

#### 1. Resetting a divider

Inside of RTC, there is 15-stage divider which generates 1 Hz clock from 32.768 kHz. Carry of a clock is not done for 0.5 second when reset this divider. So write in data at this interval.



Figure 3.13.4 Flowchart of Data Write

#### 2. Disabling the clock

Carry of a clock is prohibited when write "0" to PAGER<ENATMR> and can prevent malfunction by 1s carry hold circuit. During a clock prohibited, 1s carry hold circuit holds one second carry signal, which is generated from divider. After becoming clock enable state, output the carry signal to clock and revise time and continue operation. However, clock is late when clock-disabling state continues for one second or more.



Figure 3.13.5 Flowchart of Clock Disable

#### 3.13.6 Explanation of the Alarm Function

Can use alarm function by setting of register of PAGE1 and output either of three signal from  $\overline{\text{ALARM}}$  pin as follows by write "1" to PAGER<PAGE>. INTRTC outputs 1shot pulse when the falling edge is detected. RTC is not initializes by RESET. Therefore, when clock or alarm function is used, clear interrupt request flag in INTC (interrupt controller).

- (1) In accordance of alarm register and the clock, output "0".
- (2) Output clock of 1Hz.
- (3) Output clock of 16Hz.
- (1) In accordance with alarm register and a clock, output "0"

When value of a clock of PAGE0 accorded with alarm register of PAGE1 with a state of PAGER<ENAALM>= "1", output "0" to ALARM pin and occur INTRTC.

Follows are ways using alarm.

Initialization of alarm is done by writing in "1" at RESTR<RSTALM>, setting value of all alarm becomes don't care. In this case, always accorded with value of a clock and request INTRTC interrupt if PAGER<ENAALM> is "1".

Setting alarm min., alarm hour, alarm day and alarm the day week are done by writing in data at each register of PAGE1.

When all setting contents accorded, RTC generates INTRTC interrupt, if PAGER<INTENA><ENAALM> is "1". However, contents (don't care state) which does not set it up is considered to always accord.

The contents, which set it up once, cannot be returned to don't care state in independence. Initialization of alarm and resetting of alarm register set to "Don't care".

The following is an example program for outputting alarm from  $\overline{\text{ALARM}}$  -pin at noon (PM12:00) every day.

```
(PAGER), 09H
  LD
                                         Alarm disable, setting PAGE1
           (RESTR), D0H
                                        Alarm initialize
  ΙD
  LD
           (DAYR), 01H
                                        WO
  ID
           (DATAR),01H
                                         1 day
  ID
           (HOURR), 12H
                                        Setting 12 o'clock
           (MINR), 00H
                                        Setting 00 min
  LD
                                        Set up time 31 µs (Note)
  LD
           (PAGER), 0CH
                                        Alarm enable
( LD
           (PAGER), 8CH
                                        Interrupt enable)
```

When CPU is operated by high frequency oscillation, it may take a maximum of one clock at 32 kHz (about  $30 \mu \text{s}$ ) for the time register setting to become valid. In the above example, it is necessary to set  $31 \mu \text{s}$  of set up time between setting the time register and enabling the alarm register.

Note: This set up time is unnecessary when you use only internal interruption.

(2) When output clock of 1Hz

RTC outputs clock of 1Hz to ALARM pin by setting up PAGER<ENAALM>= "0", RESTR<DIS1HZ>= "0", <DIS16HZ>= "1". And RTC generates INTRC interrupt by falling edge of the clock.

(3) When output clock of 16Hz

RTC outputs clock of 16Hz to  $\overline{\text{ALARM}}$  pin by setting up PAGER<ENAALM>= "0", RESTR<DIS1HZ>= "1", <DIS16HZ>= "0". And RTC generates INTRC interrupt by falling edge of the clock.

### 3.14 LCD Controller (LCDC)

The TMP91C820A incorporates two types liquid crystal display driving circuit for controlling LCD Driver LSI.

• Shift-register type LCD driver control mode (SR type)

Set the mode of operation, start address of display data save memory and LCD size to SFR before start SR type.

After started SR type LCDC outputs bus release request to CPU and read data from display data memory. After that LCDC transmits data of volume of LCD size to external LCD driver through exclusive data bus (LD7:0). At this time, control signals connected LCD driver output specified waveform synchronizes with data transmission.

After finish display data reading, LCDC cancels the bus release request and CPU will restart. As the display RAM, SDRAM burst mode can be used in TMP91C820A.

• RAM built-in type LCD driver control mode (RAM mode)

Data transmission to LCD driver is executed by move instruction of CPU.

After setting mode of operation to SFR, when moves instruction of CPU is executed

LCDC outputs chip select signal to LCD driver connected to the outside from control pin (D1BSCP etc.). Therefore control of data transmission numbers corresponding to LCD size is controlled by software. At this time, LCD controller output only chip enable signal, and transmission data output from data bus (D7:0).

This section is constituted as follows.

- 3.14.1 Feature of LCDC of Each Mode
- 3.14.2 Block Diagram
- 3.14.3 SFR
- 3.14.4 Shift-Register Type LCD Driver Control Mode (SR type)
  - 3.14.4.1 Operation
  - 3.14.4.2 Gray Scale Mode Indication
  - 3.14.4.3 Memory Mapping
  - 3.14.4.4 Hardware Cursor
  - 3.14.4.5 Frame Signal Settlement
  - 3.14.4.6 Timing Charts of Interpreting Memory Codes
  - 3.14.4.7 Interface Examples at SR Mode
  - 3.14.4.8 Sample Program
- 3.14.5 RAM Built-in Type LCD Driver Control Mode (RAM type)
  - 3.14.5.1 Operation
  - 3.14.5.2 Interface Examples at Internal RAM Mode
  - 3.14.5.3 Sample Program

### 3.14.1 Feature of LCDC of Each Mode

Each feature and operation of pin is as follows.

Table 3.14.1 Feature of LCDC of Each Mode

(Example: Toshiba made LCD driver T6C13B, T6B66A)

|                                         |                                   | Shift Register Type LCD Driver<br>Control Mode                                                                                                          | RAM Built-in Type LCD Driver<br>Control Mode                                                                                                    |  |  |
|-----------------------------------------|-----------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| The number elements ca                  | r of picture<br>an be handled     | Common (Row): 128, 160, 200, 240, 320, 400, 480  Segment (Column): 128, 160, 240, 320, 400, 480, 560, 640                                               | There is not a limitation                                                                                                                       |  |  |
| Display mer width                       | mory data bus                     | 16-bit fixed                                                                                                                                            | Depend on the setting of CS/WAIT controller.                                                                                                    |  |  |
| LCD driver of                           | data bus width                    | 8-bit fixed                                                                                                                                             | controllor.                                                                                                                                     |  |  |
| Transfer rate (at f <sub>FPH</sub> = 36 |                                   | Min 55 ns/1 word at SDRAM/BURST Min 111 ns/1 word at SRAM                                                                                               |                                                                                                                                                 |  |  |
| ( 1111                                  | Data bus<br>(D7 to D0)            | Not used                                                                                                                                                | Data bus; connect to data bus of LCD driver.                                                                                                    |  |  |
|                                         | LCD data bus:<br>(LD7 to LD0)     | Data bus; connect to data bus of LCD driver.                                                                                                            | Not used                                                                                                                                        |  |  |
|                                         | Bus state                         | Not used                                                                                                                                                | Bus state; connect with write enable pin of segment/common driver.                                                                              |  |  |
|                                         | Address bus:<br>(A0)              | Not used                                                                                                                                                | Address 0; connect with D/I pin of segment driver.  When A0 = 1 data bus value means display data, when A0 = 0 data bus means instruction data. |  |  |
| External pins                           | Shift clock<br>pulse:<br>(D1BSCP) | Shift clock pulses; connect with SCP pin of segment driver. Driver latches data bus value by falling edge of this pin.                                  | Chip enable for segment driver 1; Connect with $\overline{\text{CE}}$ pin of segment driver 1.                                                  |  |  |
|                                         | Latch pulse:<br>(D2BLP)           | Latch pulses output; connect with LP pin of segment/common driver. Display data is renewed in output register in LCD driver by rising edge of this pin. | Chip enable for segment driver 2; Connect with $\overline{\text{CE}}$ pin of segment driver 2.                                                  |  |  |
|                                         | Frame:<br>(D3BFR)                 | LCD frame output; connect with FR pin of segment/common driver.                                                                                         | Chip enable for segment driver 3; Connect with $\overline{\text{CE}}$ pin of segment driver 3.                                                  |  |  |
|                                         | Cascade pulse:<br>(DLEBCD)        | Cascade pulses output; connect with DIO1 pin of row driver. These pin outputs 1 shot pulse by every D3BFR pin changes.                                  | Chip enable for common driver; Connect with $\overline{\text{LE}}$ pin of common driver.                                                        |  |  |
|                                         | Display off: ( DOFF )             | Display off output; connect with DSPOF tern display off and H means display on.                                                                         | ninal of segment/common driver. L means                                                                                                         |  |  |

#### 3.14.2 Block Diagram



Note: Row means common, and column means segment.

Figure 3.14.1 LCDC Block Diagram

#### 3.14.3 SFR

### LCD Mode Register

LCDMODE (04B0H)

|             | 7                                            | 6                                            | 5                                                          | 4      | 3                    | 2                                            | 1                                     | 0                                                  |
|-------------|----------------------------------------------|----------------------------------------------|------------------------------------------------------------|--------|----------------------|----------------------------------------------|---------------------------------------|----------------------------------------------------|
| Bit symbol  | BAE                                          | AAE                                          | SCPW1                                                      | SCPW0  | =                    | BULK                                         | RAMTYPE                               | MODE                                               |
| Read/Write  | R/W                                          | R/W                                          | R/W                                                        | R/W    | R/W                  | R/W                                          | R/W                                   | R/W                                                |
| After reset | 0                                            | 0                                            | 1                                                          | 0      | 0                    | 0                                            | 0                                     | 0                                                  |
| Function    | Used by<br>B AREA<br>0: Disable<br>1: Enable | Used by<br>A AREA<br>0: Disable<br>1: Enable | 00: Base S<br>01: 2 clocks<br>10: 4 clocks<br>11: 8 clocks | s<br>s | Always<br>write "0". | SDRAM<br>BULK<br>0: 64 Mbits<br>1: 128 Mbits | Display<br>RAM<br>0: SRAM<br>1: SDRAM | LCD<br>driver type<br>selection<br>0: RAM<br>1: SR |

Note 1: <BULK> is effective only if 1 is set to <RAMTYPE>.

Note 2: SCPW [1:0] is introduced in section 3.14.4.6.

### Divide Frame Register

LCDDVM (04B1H)

|             | 7    | 6    | 5            | 4              | 3               | 2              | 1    | 0    |  |  |
|-------------|------|------|--------------|----------------|-----------------|----------------|------|------|--|--|
| Bit symbol  | FMN7 | FMN6 | FMN5         | FMN4           | FMN3            | FMN2           | FMN1 | FMN0 |  |  |
| Read/Write  |      | R/W  |              |                |                 |                |      |      |  |  |
| After reset |      | 0    |              |                |                 |                |      |      |  |  |
| Function    |      |      | Setting Fram | ne invert adju | stment function | n bit7 to bit0 | )    |      |  |  |

## LCD Size Setting Register

LCDSIZE (04B2H)

|             | 7             | 6         | 5            | 4       | 3              | 2         | 1            | 0       |
|-------------|---------------|-----------|--------------|---------|----------------|-----------|--------------|---------|
| Bit symbol  | COM3          | COM2      | COM1         | COM0    | SEG3           | SEG2      | SEG1         | SEG0    |
| Read/Write  | R/W           | R/W       | R/W          | R/W     | R/W            | R/W       | R/W          | R/W     |
| After reset | 0             | 0         | 0            | 0       | 0              | 0         | 0            | 0       |
| Function    | Setting the I | _CD commo | n number for | SR mode | Setting the LO | D segment | number for S | SR type |
|             | 0000: 128     |           | 0101: 400    |         | 0000: 128      | 0         | 101: 480     |         |
|             | 0001: 160     |           | 0110: 480    |         | 0001: 160      | 0         | 110: 560     |         |
|             | 0010: 200     |           |              |         | 0010: 240      | 0         | 111: 640     |         |
|             | 0011: 240     |           |              |         | 0011: 320      |           |              |         |
|             | 0100: 320     |           | Other: Rese  | erved   | 0100: 400      | C         | ther: Reserv | ved     |

### LCD Control Register

LCDCTL (04B3H)



Note: This bit determines the status of  $\overline{\text{DOFF}}\ \ \text{pin}$ 

0: DOFF pin outputs 0

1: DOFF pin outputs 1

## LCD fFP Register

LCDFFP (04B4H)

|             | 7   | 6   | 5   | 4            | 3                           | 2   | 1   | 0   |  |  |
|-------------|-----|-----|-----|--------------|-----------------------------|-----|-----|-----|--|--|
| Bit symbol  | FP7 | FP6 | FP5 | FP4          | FP3                         | FP2 | FP1 | FP0 |  |  |
| Read/Write  |     | R/W |     |              |                             |     |     |     |  |  |
| After reset |     | 0   |     |              |                             |     |     |     |  |  |
| Function    |     |     |     | Setting bit7 | to bit0 for f <sub>FP</sub> |     |     |     |  |  |

## LCD Gray Level Setting Register

LCDGL (04B5H)

|             | 7 | 6 | 5 | 4 | 3 | 2 | 1            | 0     |
|-------------|---|---|---|---|---|---|--------------|-------|
| Bit symbol  |   |   |   |   |   |   | GRAY1        | GRAY0 |
| Read/Write  |   |   |   |   |   |   | R/           | W     |
| After reset |   |   |   |   |   |   | 0            | 0     |
| Function    |   |   |   |   |   |   | 00: Monoch   | rome  |
|             |   |   |   |   |   |   | 01: 4 levels | ;     |
|             |   |   |   |   |   |   | 10: 8 levels | ;     |
|             |   |   |   |   |   |   | 11: 16 leve  | ls    |

Table 3.14.2 LCD Start/End Address Register

|             | Start            | Address Re      | gister         | End Address Register |                 |                |  |
|-------------|------------------|-----------------|----------------|----------------------|-----------------|----------------|--|
|             | Н                | H M L           |                | Н                    | М               | L              |  |
|             | (bit23 to bit16) | (bit15 to bit8) | (bit7 to bit0) | (bit23 to bit16)     | (bit15 to bit8) | (bit7 to bit0) |  |
| A 0.00      | LSARAH           | LSARAM          |                | LEARAH               | LEARAM          |                |  |
| A-area      | (04C1H)          | (04C0H)         | =              | (04C3H)              | (04C2H)         | _              |  |
| After reset | 40H              | 00H             |                | 40H                  | 00H             |                |  |
| D           | LSARBH           | LSARBM          |                | LEARBH               | LEARBM          |                |  |
| B-area      | (04C5H)          | (04C4H)         | _              | (04C7H)              | (04C6H)         | _              |  |
| After reset | 40H              | 00H             |                | 40H                  | 00H             |                |  |
| C-area      | LSARCH           | LSARCM          | LSARCL         |                      |                 |                |  |
| G-area      | (04CAH)          | (04C9H)         | (04C8H)        | L                    | _               | _              |  |
| After reset | 40H              | 00H             | 00H            |                      |                 |                |  |

Note: All registers are available for R (Read)/W (Write).

### LCD Cursor Setting Register

LCDCM (04B6H)

|             | 7                         | 6                                       | 5 | 4 | 3 | 2 | 1                                                        | 0           |
|-------------|---------------------------|-----------------------------------------|---|---|---|---|----------------------------------------------------------|-------------|
| Bit symbol  | CDE                       | CCS                                     |   |   |   |   | CBE1                                                     | CBE0        |
| Read/Write  | R/W                       | R/W                                     |   |   |   |   | R/W                                                      | R/W         |
| After reset | 0                         | 0                                       |   |   |   |   | 0                                                        | 0           |
| Function    | Cursor<br>0: OFF<br>1: ON | Cursor<br>color<br>0: White<br>1: Black |   |   |   |   | Oursor blin  00: Don't b  01: 2 Hz  10: 1 Hz  11: 0.5 Hz | (fs:32 kHz) |

Note 1: The function of cursor blink is effective only when low-frequency oscillator is input.

Note 2: The function of cursor blink depends on the low-frequency oscillator (fs) even if you use timer out (TA3OUT) as LCDCK.

### LCD Cursor Width Setting Register

LCDCW (04B7H)

|             | 7 | 6 | 5 | 4   | 3    | 2             | 1    | 0   |
|-------------|---|---|---|-----|------|---------------|------|-----|
| Bit symbol  |   |   |   | CW4 | CW3  | CW2           | CW1  | CW0 |
| Read/Write  |   |   |   | R/W | R/W  | R/W           | R/W  | R/W |
| After reset |   |   |   | 0   | 0    | 0             | 0    | 0   |
| Function    |   |   |   |     | Curs | or width      |      |     |
|             |   |   |   |     | 0000 | 00: 1 dot (Mi | n)   |     |
|             |   |   |   |     | 1111 | 11: 32 dots ( | Max) |     |

### LCD Cursor Height Setting Register

LCDCH (04B8H)

|             |   |   |   | 9   | 9 9  |               |      |     |
|-------------|---|---|---|-----|------|---------------|------|-----|
|             | 7 | 6 | 5 | 4   | 3    | 2             | 1    | 0   |
| Bit symbol  |   |   |   | CH4 | CH3  | CH2           | CH1  | CH0 |
| Read/Write  |   |   |   | R/W | R/W  | R/W           | R/W  | R/W |
| After reset |   |   |   | 0   | 0    | 0             | 0    | 0   |
| Function    |   |   |   |     | Curs | sor height    |      |     |
|             |   |   |   |     | 0000 | 00: 1 dot (Mi | n)   |     |
|             |   |   |   |     | 111  | 11: 32 dots ( | Max) |     |

## LCD Cursor Start Address Setting Register

LCDCPL (04BAH)

|             | 7    | 6                                             | 5    | 4    | 3    | 2    | 1    | 0    |  |  |
|-------------|------|-----------------------------------------------|------|------|------|------|------|------|--|--|
| Bit symbol  | CAP7 | CAP6                                          | CAP5 | CAP4 | CAP3 | CAP2 | CAP1 | CAP0 |  |  |
| Read/Write  | R/W  | R/W                                           | R/W  | R/W  | R/W  | R/W  | R/W  | R/W  |  |  |
| After reset | 0    | 0 0 0 0 0 0 0                                 |      |      |      |      |      |      |  |  |
| Function    |      | Setting bit7 to bit0 for cursor start address |      |      |      |      |      |      |  |  |

### LCD Cursor Start Address Setting Register

LCDCPM (04BBH)

|             | 7     | 6                                              | 5     | 4     | 3     | 2     | 1    | 0    |  |
|-------------|-------|------------------------------------------------|-------|-------|-------|-------|------|------|--|
| Bit symbol  | CAP15 | CAP14                                          | CAP13 | CAP12 | CAP11 | CAP10 | CAP9 | CAP8 |  |
| Read/Write  | R/W   | R/W                                            | R/W   | R/W   | R/W   | R/W   | R/W  | R/W  |  |
| After reset | 0     | 0                                              | 0     | 0     | 0     | 0     | 0    | 0    |  |
| Function    |       | Setting bit15 to bit8 for cursor start address |       |       |       |       |      |      |  |

### LCD Cursor Start Address Setting Register

LCDCPH (04BCH)

|             | 7     | 6                                               | 5     | 4     | 3     | 2     | 1     | 0     |  |
|-------------|-------|-------------------------------------------------|-------|-------|-------|-------|-------|-------|--|
| Bit symbol  | CAP23 | CAP22                                           | CAP21 | CAP20 | CAP19 | CAP18 | CAP17 | CAP16 |  |
| Read/Write  | R/W   | R/W                                             | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   |  |
| After reset | 0     | 1                                               | 0     | 0     | 0     | 0     | 0     | 0     |  |
| Function    |       | Setting bit23 to bit16 for cursor start address |       |       |       |       |       |       |  |

### LCD Cursor Hot Point Pixel Number (Bit correction) Setting Register

LCDCP (04B9H)

|             | 7 | 6 | 5 | 4 | 3                                                          | 2    | 1    | 0    |  |  |
|-------------|---|---|---|---|------------------------------------------------------------|------|------|------|--|--|
| Bit symbol  |   |   |   |   | APB3                                                       | APB2 | APB1 | APB0 |  |  |
| Read/Write  |   |   |   |   |                                                            | RΛ   | N    |      |  |  |
| After reset |   |   |   |   | 0                                                          |      |      |      |  |  |
| Function    |   |   |   |   | Setting bit 3 to bit0 of pixel for correction of hot point |      |      |      |  |  |
|             |   |   |   |   | (for 1-dot correction)                                     |      |      |      |  |  |

LCDC1L, LCDC1H, LCDC2L, LCDC2H, LCDC3L, LCDC3H, LCDR1L, LCDR1H Register

|             | 7  | 6                                                   | 5  | 4  | 3  | 2  | 1  | 0  |  |
|-------------|----|-----------------------------------------------------|----|----|----|----|----|----|--|
| Bit symbol  | D7 | D6                                                  | D5 | D4 | D3 | D2 | D1 | D0 |  |
| Read/Write  |    | Depend on the specification of external LCD driver. |    |    |    |    |    |    |  |
| After reset |    | Depend on the specification of external LCD driver. |    |    |    |    |    |    |  |
| Function    |    | Depend on the specification of external LCD driver. |    |    |    |    |    |    |  |

These registers do not exist on TMP91C820A. These are image for instruction registers and display registers of external RAM built-in sequential access type LCD driver.

Address as Table 3.14.3 is assigned to these registers, and the following chip enable pin becomes active when accesses corresponding address.

And, the area of these address is external area, so  $\overline{RD}$ ,  $\overline{WR}$  terminal becomes active by external access.

Table 3.14.4 shows the address map in the case of controlling RAM built-in random access type LCD driver.

The explanation part of MMU circuit also explains this.

This setup is performed by LCDCTL <MMULCD>.

Table 3.14.3 Memory Mapping for Built-in RAM Sequential Access Type

| Register | Address | Pui<br>Sequential | Chip Enable<br>Terminal | A0<br>Terminal |   |
|----------|---------|-------------------|-------------------------|----------------|---|
| LCDC1L   | 0FE0H   | RAM built-in type | Instruction             | D1BSCP         | 0 |
| LCDC1H   | 0FE1H   | driver 1          | Display data            | DIBSCF         | 1 |
| LCDC2L   | 0FE2H   | RAM built-in type | Instruction             | D2BLP          | 0 |
| LCDC2H   | 0FE3H   | driver 2          | Display data            | DZBLP          | 1 |
| LCDC3L   | 0FE4H   | RAM built-in type | Instruction             | D3BFR          | 0 |
| LCDC3H   | 0FE5H   | driver 3          | Display data            | DOBER          | 1 |
| LCDR1L   | 0FE6H   | ROW driver        | Instruction             | DLEBCD         | 0 |
| LCDR1H   | 0FE7H   |                   | Display data            | DLEBOD         | 1 |

Table 3.14.4 Memory Mapping for Built-in RAM Random Access Type

| Address            | Purpose                    | Chip Enable |
|--------------------|----------------------------|-------------|
| Address            | Random Access Type         | Terminal    |
| 3C0000H to 3CFFFFH | RAM built-in type driver 1 | D1BSCP      |
| 3D0000H to 3DFFFFH | RAM built-in type driver 2 | D2BLP       |
| 3E0000H to 3EFFFFH | RAM built-in type driver 3 | D3BFR       |
| 3F0000H to 3FFFFFH | RAM built-in type driver 4 | DLEBCD      |

Note 1: We call built-in RAM sequential access type LCD driver that use register to access to display RAM without address. (e.g., T6B65A, T6C84 etc: mar/2000)

Note 2: We call built-in RAM random access type LCD driver that is same method to access to SRAM. (e.g., T6C23, T6K01 etc: mar/2000)

#### 3.14.4 Shift-Register Type LCD Driver Control Mode (SR type)

#### 3.14.4.1 Operation

Set the mode of operation, start address of display data save memory, gray-scale level and LCD size to control registers before start SR type.

After start it LCDC outputs bus release request to CPU and read data from display data memory. After that LCDC transmits data of volume of LCD size to external LCD driver through LCD personal data bus (LD7:0). At this time, control signals (D1BSCP etc.) connected LCD driver output specified waveform synchronizes with data transmission. After finish data transmission, LCDC cancels the bus release request and CPU will restart. LCD controller use LCDCK for generation waveform of D3BFR, DLEBCD and D2BLP pins. LCDCK select TAOUT that be outputted from low frequency oscillator (fs): 32.768kHz or internal TMRA23 by setting EMCCR0 <TA3LCDE> register. <TA3LCDE> is cleared to "0" by external reset, and low frequency oscillator (fs) is set.

Note: When set LCDC to SR type, during data reading (during DMA operation), CPU is stopped by internal BUSREQ signal. When using SR type LCDC, programmer need to care the CPU stop time. For detail, see the Table 3.14.8.

#### 3.14.4.2 Gray Scale Mode Indication

Monochrome, 4-, 8- and 16-gray scale mode can be selected by setting LCDGL <GRAY1:0>.

And when SDRAM mode, you can select the size of SDRAM by setting (LCDMODE) <BULK>.

TMP91C820A realize gray scale display by thinning out the frame. Gray scale control palette is defined by 16-bit register (LGnL/H) shown in Table 3.14.5. Palette is selected according to the gray scale level (Monochrome, 4, 8, 16 gray) for use. (Ref. Table 3.14.6). On/off for data of each level (e.g., each density) can modify by 16-bit register (LGnL/H). However each resister of palette has an initial value, it is possible to adjust finely which matches to LCD driver you use and the characteristic of LCD panel.

D3BFR Level **Data Setting Register** bit0 3 5 7 Density 1 2 4 6 8 9 10 11 12 13 14 15 Code (Address/after reset) F 16/16 LGFH/L (04EF-E/FFFFH) • • • • • • • • F 14/16 LGEH/L (04ED-C/FDFDH) • 0 • • • • • • • • • • 1316 LGDH/L (04EB-A/FDDDH) • 0 • • • 0 • • • • D • 12/16 • 0 • • 0 • • 0 • 0 • C LGCH/L (04E9-8/DDDDH) • 11/16 LGBH/L (04E7-6/DDD5H) • 0 • 0 • • • • 0 • • • 0 • • В 0 0 0 0 • 10/16 • • • 0 • • • • 0 • • LGAH/L (04E5-4/D5D5H) 9 9/16 LG9H/L (04E3-2/D555H) 0 0 0 0 • • 0 8/16 LG8H/L (04E1-0/AAAAH) 0 0 • 0 • • 0 • 0 8 • • • 7 7/16 LG7H/L (04DF-E/8AAAH) 0 0 0 0 0 0 6/16 0 0 0 • 0 • 0 0 0 • 6 LG6H/L (04DD-C/8A8AH) • • 0 5/16 LG5H/L (04DB-A/888AH) 0 • 0 0 0 • 0 0 0 0 0 0 • 5 4/16 LG4H/L (04D9-8/8888H) 0 0 0 • 0 0 • 0 0 0 • 0 0 0 • LG3H/L (04D7-6/8880H) 0 0 0 0 0 0 • 0 0 0 • 0 0 0 • 3 3/16 0 2/16 LG2H/L (04D5-4/8080H) 0 0 0 0 • 0 0 0 0 ulletLG1H/L (04D3-2/8000H) 0 1/16 0 0 0 0 0 0 0 0 0 0 0 0 0 0 • 1 0 0 0 0 0 0 0/16 LG0H/L (04D1-0/0000H) 0 0 0 0 0 0 0 0 0

Table 3.14.5 Gray Scale Control Palette Default Setting

Table 3.14.6 Gray Scale Control Palette Effective Registers for Each Gray Level

|               | LG0 | LG1 | LG2 | LG3 | LG4 | LG5 | LG6 | LG7 | LG8 | LG9 | LGA | LGB | LGC | LGD | LGE | LGE |
|---------------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
|               | L/H |
| 16-gray level | •   | •   | •   | •   | •   | •   | •   | •   | •   | •   | •   | •   | •   | •   | •   | •   |
| 8-gray level  | •   | ×   | •   | ×   | •   | ×   | •   | ×   | •   | ×   | •   | ×   | •   | ×   | ×   | •   |
| 4-gray level  | •   | ×   | ×   | ×   | •   | ×   | ×   | ×   | •   | ×   | ×   | ×   | ×   | ×   | ×   | •   |
| Monochrome    | •   |     |     |     |     |     |     |     |     |     |     |     |     |     |     | •   |

<sup>×:</sup> Don't care, ●: Effective

<sup>●:</sup> Display ON, O: Display OFF

#### 3.14.4.3 Memory Mapping

The LCDC can display the LCD panel image which is divided horizontally into 3 parts; upper, middle and lower. Each area calls A, B and C area that has some characteristics showing below.

Start/end address of each area in the physical memory space can be defined in the LCD start/end address registers (See Table 3.14.2). (C area can be defined only start address.)

A and B areas are selectable enable or not in LCDMODE register. When A and B area are disable, the C area take over all panel space.

The displaying priority is A > B > C. If the A area set to enable while the panel area is defined as all C area (That is A and B area are disable), C area is shifted to under the LCD panel and A area is inserted from the top of the LCD panel. Similarly if the B area set to enable while the panel area is defined as all C area, B area is inserted from the bottom of the C area overlapping.



Figure 3.14.2 Memory Mapping from Physical Memory to LCD Panel

Display memory mapping and panning function

LCDC can change the panel window if only you change each start address of A and B area can be vertical panned by changing row address. While C area can be vertical and horizontal panned by changing row and column address.

An important thing is that display data from one line to the next line, cannot be input continuously even if you don't use the panning function. One row address of display RAM corresponds to 1st line of display panel. Now display data of 2nd line cannot be set within the 1st row address of display RAM even if the necessary data for the size you want to display do not fill the capacity of 1st row address of display RAM. Adding the one line to display panel is equal to adding one address to row address of display RAM.

And another important thing is, this limitation is also for SRAM as display RAM without address multiplex. When you use SDRAM as display RAM, you can select the size for display RAM capacity of one line. But in case of using SRAM, display RAM capacity of one line is fixed to 512 bytes.



Figure 3.14.3 Memory Mapping Image for SRAM as Display RAM (Only A and B area)

TMP91C820A can select four display scale; monochrome, 4 gray, 8 gray and 16 gray. With the intrinsic property of gray levels, a pixel is decoded in each gray level from different memory size.

A pixel use a bit in memory for monochrome, while a pixel use 2 bits in memory for 4 gray, 3 bits for 8 gray and 4 bits for 16 gray. Sing bits of display memory has some differences for each gray scale or sort of memory.



Figure 3.14.4 Gray display and using bit in memory

And "px" in above Figure 3.14.4 corresponds to the image of LCD panel as below (Figure 3.14.5). But TMP91C820A outputs data of px0 to PE7 (LD7), and data of px7 to PE0 (LD0). Therefore PE0 (LD0) should be connected to the MSB of LCD driver (e.g., DI7) according to LCD driver you use. Please note that the way TMP91C820A outputs the data differs from LCD controller built in TLCS-900/L1 series of TOSHIBA (e.g., TMP91C815, TMP91C016, TMP91C025 etc.).



Figure 3.14.5 Connection between LCD Bus of TMP91C820A and Data Bus of LCDD

#### 3.14.4.4 Hardware Cursor

TMP91C820A has a cursor that is blinking interval, color and size can be specified, and maximum size is 32X32.

A programmer can control the cursor attributes easily by filling those cursor registers, for example color (white/black), blinking interval time, size and intimate pixel location. Its space location is specified by left-up hot point. (See the Figure 3.14.6.)

The precise location of the hot point is determined by memory address (LCDCPH, LCDCPM, LCDCPL) and pixel correction number (LCDCP). For example, however 1 pixel for displaying needs 2 bits of setting data under 4-gray mode, you can correct the location of hot point every pixel by setting pixel number which you want to move in the resister (LCDCP).

Cursor image is showed under the setting A, B, C area are enable, 4-gray mode, start address = 410004\_hex and correction bit (LCDCP) = 3\_hex in the following figure.



Note: TMP91C820A sets the hardware cursor in the memory address. If panning function is set to enable during hardware cursor displaying, the cursor in the pannel moves, but start address of cursor is not changed.

Figure 3.14.6 Cursor Hot Point Position and Size, Cursor start address

#### LCD Cursor Setting Register

LCDCM (04B6H)

|             | 7                         | 6                                       | 5 | 4 | 3 | 2 | 1                                                  | 0            |
|-------------|---------------------------|-----------------------------------------|---|---|---|---|----------------------------------------------------|--------------|
| Bit symbol  | CDE                       | CCS                                     |   |   |   |   | CBE1                                               | CBE0         |
| Read/Write  | R/W                       | R/W                                     |   |   |   |   | R/W                                                | R/W          |
| After reset | 0                         | 0                                       |   |   |   |   | 0                                                  | 0            |
| Function    | Cursor<br>0: OFF<br>1: ON | Cursor<br>color<br>0: White<br>1: Black |   |   |   |   | O0: Don't bl<br>01: 2 Hz<br>10: 1 Hz<br>11: 0.5 Hz | (fs: 32 kHz) |

Note 1: The function of cursor blink is effective only when low-frequency osdillator is input.

Note 2: The function of cursor blink depends on the low-frequency oscillator (fs) even if you use timer out "TA3OUT" as LCDCK.

#### LCD Cursor Width Setting Register

LCDCW (04B7H)

|             | 7 | 6 | 5 | 4                    | 3   | 2   | 1   | 0   |  |  |
|-------------|---|---|---|----------------------|-----|-----|-----|-----|--|--|
| Bit symbol  |   |   |   | CW4                  | CW3 | CW2 | CW1 | CW0 |  |  |
| Read/Write  |   |   |   | R/W                  | R/W | R/W | R/W | R/W |  |  |
| After reset |   |   |   | 0                    | 0   | 0   | 0   | 0   |  |  |
| Function    |   |   |   | Cursor widt          | h   |     |     |     |  |  |
|             |   |   |   | 00000: 1 dot (MIN)   |     |     |     |     |  |  |
|             |   |   |   | 11111: 32 dots (MAX) |     |     |     |     |  |  |

## LCD Cursor Height Setting Register

LCDCH (04B8H)

|             | 7 | 6 | 5 | 4                                         | 3        | 2   | 1   | 0   |
|-------------|---|---|---|-------------------------------------------|----------|-----|-----|-----|
| Bit symbol  |   |   |   | CH4                                       | CH3      | CH2 | CH1 | CH0 |
| Read/Write  |   |   |   | R/W                                       | R/W      | R/W | R/W | R/W |
| After reset |   |   |   | 0                                         | 0        | 0   | 0   | 0   |
| Function    |   |   |   | Cursor heig<br>00000: 1 do<br>11111: 32 d | ot (MIN) |     |     |     |

### LCD Cursor Start Address Setting Register

LCDCPL (04BAH)

|             | 7    | 6                                             | 5    | 4    | 3    | 2    | 1    | 0    |  |
|-------------|------|-----------------------------------------------|------|------|------|------|------|------|--|
| Bit symbol  | CAP7 | CAP6                                          | CAP5 | CAP4 | CAP3 | CAP2 | CAP1 | CAP0 |  |
| Read/Write  | R/W  | R/W                                           | R/W  | R/W  | R/W  | R/W  | R/W  | R/W  |  |
| After reset | 0    | 0                                             | 0    | 0    | 0    | 0    | 0    | 0    |  |
| Function    |      | Setting bit7 to bit0 for cursor start address |      |      |      |      |      |      |  |

#### LCD Cursor Start Address Setting Register

LCDCPM (04BBH)

|             | 7     | 6                                              | 5     | 4     | 3     | 2     | 1    | 0    |  |
|-------------|-------|------------------------------------------------|-------|-------|-------|-------|------|------|--|
| Bit symbol  | CAP15 | CAP14                                          | CAP13 | CAP12 | CAP11 | CAP10 | CAP9 | CAP8 |  |
| Read/Write  | R/W   | R/W                                            | R/W   | R/W   | R/W   | R/W   | R/W  | R/W  |  |
| After reset | 0     | 0                                              | 0     | 0     | 0     | 0     | 0    | 0    |  |
| Function    |       | Setting bit15 to bit8 for cursor start address |       |       |       |       |      |      |  |

### LCD Cursor Start Address Setting Register

LCDCPH (04BCH)

|             | 7                                               | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
|-------------|-------------------------------------------------|-------|-------|-------|-------|-------|-------|-------|
| Bit symbol  | CAP23                                           | CAP22 | CAP21 | CAP20 | CAP19 | CAP18 | CAP17 | CAP16 |
| Read/Write  | R/W                                             | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   |
| After reset | 0                                               | 1     | 0     | 0     | 0     | 0     | 0     | 0     |
| Function    | Setting bit23 to bit16 for cursor start address |       |       |       |       |       |       |       |

### LCD Cursor Hot Point Pixel correction Setting Register

LCDCP (04B9H)

|             | 7 | 6 | 5 | 4 | 3                                                                       | 2    | 1    | 0    |
|-------------|---|---|---|---|-------------------------------------------------------------------------|------|------|------|
| Bit symbol  |   |   |   |   | APB3                                                                    | APB2 | APB1 | APB0 |
| Read/Write  |   |   |   |   |                                                                         | R/\  | ٧    |      |
| After reset |   |   |   |   |                                                                         | 0    |      |      |
| Function    |   |   |   |   | Setting bit3 to bit0 for correction of hot point (for 1-dot correction) |      |      |      |

Table 3.14.7 Pixel correct and register setting

| In case of monochrome (SRAM mode) | 0000: 0 Pixel correct<br>0111: 7 Pixels correct<br>1111: 15 Pixels correct |                        |
|-----------------------------------|----------------------------------------------------------------------------|------------------------|
| In case of monochrome             | x000: 0 Pixel correct                                                      | x100: 4 Pixels correct |
| (SDRAM mode) and 4 gray           | x001: 1 Pixel correct                                                      | x101: 5 Pixels correct |
| (SRAM/SDRAM mode)                 | x010: 2 Pixels correct                                                     | x110: 6 Pixels correct |
|                                   | x011: 3 Pixels correct                                                     | x111: 7 Pixels correct |
| In case of 8 gray and 16 gray     | xx00: 0 Pixel correct                                                      | xx10: 2 Pixels correct |
| (SRAN/SDRAM mode)                 | xx01: 1 Pixel correct                                                      | xx11: 3 Pixels correct |

X: Don't care

Here, it is possible to correct the cursor per pixel from the start address set before. Pixel number should be adjusted in response to the gray mode setting showing above.

For example, when 4-gray and 16-bit BUS mode, correction should be less than 7 pixels because the smallest pixel is 8 pixels that can set by start address setting. Similarly correction pixel should be less than 15 at monochrome mode, 3- at 8- or 16-gray mode.

(e.g.) When monochrome mode, correction value is (LCDCP) = 011\_hex, and cursor size =  $(8 \times 8)$ 



Figure 3.14.7 The Location Hot Point by Setting of Pixel

TOSHIBA

# 3.14.4.5 Frame Signal Settlement

TMP91C820A defines so called frame period (Refresh interval for LCD panel) by the value set in fFP [9:0]. DLEBCD pin outputs pulse every frame period. DLEBFR pin usually outputs the signal inverts polarity every frame period.

And TMP91C820A has a special function that can set the timing of inverting frame polarity irrelevant to above frame frequency for the purpose of preventing the patches of display.

# LCD Control Register

LCDCTL (04B3H)

|             | 7                                        | 6                                                                               | 5                                             | 4   | 3                         | 2                                                                              | 1                                            | 0                                                     |
|-------------|------------------------------------------|---------------------------------------------------------------------------------|-----------------------------------------------|-----|---------------------------|--------------------------------------------------------------------------------|----------------------------------------------|-------------------------------------------------------|
| Bit symbol  | LCDON                                    | ALL0                                                                            | FRMON                                         | -   | FP9                       | MMULCD                                                                         | FP8                                          | START                                                 |
| Read/Write  | R/W                                      | R/W                                                                             | R/W                                           | R/W | R/W                       | R/W                                                                            | R/W                                          | R/W                                                   |
| After reset | 0                                        | 0                                                                               | 0                                             | 0   | 0                         | 0                                                                              | 0                                            | 0                                                     |
| Function    | DOFF port  0: Display OFF  1: Display ON | Setting all<br>column<br>ports to 0<br>0: Normal<br>1: All<br>display<br>data 0 | Divided FR<br>mode<br>0: Disable<br>1: Enable | ,   | for f <sub>FP</sub> [9:0] | Specify<br>address of<br>LCD driver<br>with built-in<br>RAM<br>0: OFF<br>1: ON | Setting<br>bit8 for<br>f <sub>FP</sub> [9:0] | Start<br>control in<br>SR mode<br>0: Stop<br>1: Start |

# LCD fFP Register

LCDFFP (04B4H)

|             | 7   | 6                             | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |  |
|-------------|-----|-------------------------------|---|---|---|---|---|---|--|--|--|--|
| Bit symbol  | FP7 | 7 FP6 FP5 FP4 FP3 FP2 FP1 FP0 |   |   |   |   |   |   |  |  |  |  |
| Read/Write  |     | R/W                           |   |   |   |   |   |   |  |  |  |  |
| After reset |     |                               |   |   | 0 |   |   |   |  |  |  |  |
| Function    |     | Setting bit7 to bit0 for fFP  |   |   |   |   |   |   |  |  |  |  |

# Divide FRM Register

LCDDVM (04B1H)

|             | 7    | 6                        | 5    | 4    | 3    | 2    | 1    | 0    |  |  |  |  |
|-------------|------|--------------------------|------|------|------|------|------|------|--|--|--|--|
| Bit symbol  | FMN7 | FMN6                     | FMN5 | FMN4 | FMN3 | FMN2 | FMN1 | FMN0 |  |  |  |  |
| Read/Write  |      | R/W                      |      |      |      |      |      |      |  |  |  |  |
| After reset |      | 0                        |      |      |      |      |      |      |  |  |  |  |
| Function    |      | Setting DVM bit7 to bit0 |      |      |      |      |      |      |  |  |  |  |

TMP91C820A

# (1) Frame frequency setting

Basic frame period; DLEBCD signal, is made according to the resister ffp [9:0] setting mentioned before. However this ffp [9:0] setting is generally equal to common number, frame period can be corrected by increasing ffp [9:0] with ease. This function cannot correct frame frequency higher than that of Table 3.14.8. If it is necessary to set frame frequency higher or detailed, please refer to (3) "Timer out LCDCK".

The equation can calculate frame period.

Frame period = LCDCK/(D  $\times$  f<sub>FP</sub>) [Hz] D: Constant for each common (Table 3.14.8)

f<sub>FP</sub>: Setting of f<sub>FP</sub> [9:0] register

LCDCK: Source clock of LCD

(Low clock is usually selected)

Please select the value of ffp [9:0] as the frame period you want to set in the Table 3.14.7.

Note: Please make the value set to fFP [9:0] into the following range.

COM (common number)  $\leq$  FR  $\leq$  1024

(e.g.) In the case where frame period is set to 72.10 Hz by 240 coms.

 $f_{FP} = 240 \text{ (COM)} + 63 = 303 = 12\text{FH (by Table 3.14.8)}$ 

Therefore, LCDCTL<FP8> = 1 and LCDFFP<FP7:0> = 2FH are setup.

#### (2) Frame invert adjustment function

This mode can prevent the deterioration of display (e.g., patches of display). (\*Note) If N is set in (LCDDVM) register while this function is set to enable in register (LCDCTL) (<FRMON> "1"), D3BFR pin outputs the signal inverted polarity every (D2BLP x N) timing.

If this function isn't necessary, D3BFR pin outputs the signal inverted polarity every frequency of DLEBCD pin after setting this function disable ((LCDCTL)<FRMON> = 0).

And it is no change wave and timing for DLEBCD pin by LCDDVM setting.

Note: Effects of this function have some differences as the LCD driver or LCD panel you use actually.

#### (3) Timer out LCDCK

LCD source clock (LCDCK) can select low frequency (fs: 32.768 [kHz]) or timer out (TA3OUT) outputs from internal TMRA23.

(e.g.) Here indicates the method that frame period is set 70 [Hz] by selecting TA3OUT for source clock of LCD. (fc = 6 [MHz], 128 COM)

The next equation calculates frame period.

Frame period =  $1/(t_{LP} \times f_{FP})$  [Hz]

tLP: The period of D2BLP

Source clock for LCDC defines as XT [Hz] and then this tLP represents

$$t_{LP} = D/XT$$

D: The value is 3 at 128 COM

Therefore if you set the frame period at 70 [Hz] under 128 COM,

$$XT = 128 \times 3.5 \times 70$$

= 26880 [Hz]

XT should be above value.

In order to make XT = 26880 [Hz] under fc = 6 [MHz] with  $\phi T1$  of timer 3,

$$1/XT = T3 \times 2 \times 8/fc$$
 [s]

T3: The value of timer register (TA3REG)

in short,  $XT = fc/(T3 \times 2 \times 8)$  [Hz]

However T3 = (TA3REG) is 13.95 after calculate, it's impossible to set the value under a decimal point.

So if T3 = (TA3REG) is set 0DH, XT = 28846 [Hz]. And because of D = 3,

Frame period =  $28846/(128 \times 3)$ 

= 75.12 [Hz]

Further if fFP is 136 (COM + 8) with correction,

Frame period = 
$$28846/(136 \times 3)$$

= 70.70 [Hz]

Reference: To maintain quality for display, please refer to following value for each gray scale.

(You have to use frame frequency setting, frame invert adjustment function and timer out LCDCK.)

Monochrome: Frame period = 70 [Hz]

4 or 8 or 16 gray: Frame period = 140 [Hz]



Figure 3.14.8 Timing Diagram for SR Mode



Figure 3.14.9 Timing Diagram for SR Mode (Detail)

D3BFR waveform (in case of 240 row + 63 (FFP) and LCDDVM<FMN7:0> = 0B\_hex)



Figure 3.14.10 D2BLP and D3BFR Waveform

Table 3.14.8 f<sub>FP</sub> Table for Each Common Number (1/2)

| D        | 6.5            | 6.0   | 5.0            | 4.0            | 3.5   | 3.0            | 2.5   | 2.5            | 2.0   | 1.5            | Unit  |
|----------|----------------|-------|----------------|----------------|-------|----------------|-------|----------------|-------|----------------|-------|
| СОМ      |                |       |                |                |       |                |       |                |       |                | Offic |
| number   | 64             | 68    | 80             | 100            | 120   | 128            | 144   | 160            | 200   | 240            |       |
| COM + 0  | 78.77          | 80.31 | 81.92          | 81.92          | 78.02 | 85.33          | 91.02 | 81.92          | 81.92 | 91.02          |       |
| COM + 1  | 77.56          | 79.15 | 80.91          | 81.11          | 77.37 | 84.67          | 90.39 | 81.41          | 81.51 | 90.64          |       |
| COM + 2  | 76.38          | 78.02 | 79.92          | 80.31          | 76.74 | 84.02          | 89.78 | 80.91          | 81.11 | 90.27          |       |
| COM + 3  | 75.24          | 76.92 | 78.96          | 79.53          | 76.12 | 83.38          | 89.16 | 80.41          | 80.71 | 89.90          |       |
| COM + 4  | 74.14          | 75.85 | 78.02          | 78.77          | 75.50 | 82.75          | 88.56 | 79.92          | 80.31 | 89.53          |       |
| COM + 5  | 73.06          | 74.81 | 77.10          | 78.02          | 74.90 | 82.13          | 87.97 | 79.44          | 79.92 | 89.16          |       |
| COM + 6  | 72.02          | 73.80 | 76.20          | 77.28          | 74.30 | 81.51          | 87.38 | 78.96          | 79.53 | 88.80          |       |
| COM + 7  | 71.00          | 72.82 | 75.33          | 76.56          | 73.72 | 80.91          | 86.80 | 78.49          | 79.15 | 88.44          |       |
| COM + 8  | 70.02          | 71.86 | 74.47          | 75.85          | 73.14 | 80.31          | 86.23 | 78.02          | 78.77 | 88.09          |       |
| COM + 9  | 69.06          | 70.93 | 73.64          | 75.16          | 72.58 | 79.73          | 85.67 | 77.56          | 78.39 | 87.73          |       |
| COM + 10 | 68.12          | 70.02 | 72.82          | 74.47          | 72.02 | 79.15          | 85.11 | 77.10          | 78.02 | 87.38          |       |
| COM + 11 | 67.22          | 69.13 | 72.02          | 73.80          | 71.47 | 78.58          | 84.56 | 76.65          | 77.65 | 87.03          |       |
| COM + 12 | 66.33          | 68.27 | 71.23          | 73.14          | 70.93 | 78.02          | 8.02  | 76.20          | 77.28 | 86.69          |       |
| COM + 13 | 65.48          | 67.42 | 70.47          | 72.50          | 70.39 | 77.47          | 83.49 | 75.76          | 76.92 | 86.35          |       |
| COM + 14 | 64.63          | 66.60 | 69.72          | 71.86          | 69.87 | 76.92          | 82.96 | 75.33          | 76.56 | 86.01          |       |
| COM + 15 | 63.81          | 65.80 | 68.99          | 71.23          | 69.35 | 76.38          | 81.92 | 74.90          | 76.20 | 85.67          |       |
| COM + 16 | 63.02          | 65.02 | 68.27          | 70.62          | 68.84 | 75.85          | 81.41 | 74.47          | 75.85 | 85.33          |       |
| COM + 17 | 62.24          | 64.25 | 67.56          | 70.02          | 68.34 | 75.33          | 80.91 | 74.05          | 75.50 | 85.00          |       |
| COM + 18 | 61.48          | 63.50 | 66.87          | 69.42          | 67.84 | 74.81          | 80.41 | 73.64          | 75.16 | 84.67          |       |
| COM + 19 | 60.74          | 62.77 | 66.20          | 68.84          | 67.35 | 74.30          | 79.92 | 73.22          | 74.81 | 84.34          |       |
| COM + 20 | 60.01          | 62.06 | 65.54          | 68.27          | 66.87 | 73.80          | 79.44 | 72.82          | 74.47 | 84.02          |       |
| COM + 21 | 59.31          | 61.36 | 64.89          | 67.70          | 66.40 | 73.31          | 78.96 | 72.42          | 74.14 | 83.70          |       |
| COM + 22 | 58.62          | 60.68 | 64.25          | 67.15          | 65.93 | 72.82          | 78.49 | 72.02          | 73.80 | 83.38          |       |
| COM + 23 | 57.95          | 60.01 | 63.63          | 66.60          | 65.47 | 72.34          | 78.02 | 71.62          | 73.47 | 83.06          |       |
| COM + 24 | 57.29          | 59.36 | 63.02          | 66.06          | 65.02 | 71.86          | 77.56 | 71.23          | 73.14 | 82.75          |       |
| COM + 25 | 56.64          | 58.72 | 62.42          | 65.54          | 64.57 | 71.39          | 77.10 | 70.85          | 72.82 | 82.44          | Hz    |
| COM + 26 | 56.01          | 58.10 | 61.83          | 65.02          | 64.13 | 70.93          | 76.65 | 70.47          | 72.50 | 82.13          |       |
| COM + 27 | 55.40          | 57.49 | 61.25          | 64.50          | 63.69 | 70.47          | 76.20 | 70.09          | 72.18 | 81.82          |       |
| COM + 28 | 54.80          | 56.89 | 60.68          | 64.00          | 63.26 | 70.02          | 75.76 | 69.72          | 71.86 | 81.51          |       |
| COM + 29 | 54.21          | 56.30 | 60.12          | 63.50          | 62.83 | 69.57          | 75.33 | 69.35          | 71.55 | 81.21          |       |
| COM + 30 | 53.63          | 55.73 | 59.58          | 63.02          | 62.42 | 69.13          | 74.91 | 68.99          | 71.23 | 80.91          |       |
| COM + 31 | 53.07          | 55.16 |                |                |       |                |       |                | 70.93 |                |       |
| COM + 31 | 52.51          | 54.61 | 59.04<br>58.51 | 62.53<br>62.06 | 62.00 | 68.70          | 74.47 | 68.62<br>68.27 | 70.62 | 80.61          |       |
| COM + 32 | 51.97          | 54.07 | 58.00          |                |       |                | 74.03 | 67.91          | 70.02 | 80.02          |       |
|          |                |       |                | 61.59          | 61.19 | 67.84          | 70.64 |                |       |                |       |
| COM + 34 | 51.44<br>50.92 | 53.54 | 57.49          | 61.13          | 60.79 | 67.42          | 73.64 | 67.56          | 70.02 | 79.73          |       |
| COM + 35 |                | 53.02 | 56.99          | 60.68          | 60.40 | 67.01<br>66.60 | 73.22 | 67.22          | 69.72 | 79.44          |       |
| COM + 36 | 50.41          | 52.51 | 56.50          | 60.24<br>59.80 | 60.01 |                | 72.82 | 66.87          | 69.42 | 79.15<br>78.86 |       |
| COM + 37 | 49.91          | 52.01 | 56.01          |                | 59.63 | 66.20          | 72.42 | 66.53          | 69.13 |                |       |
| COM + 38 | 49.42          | 51.52 | 55.54          | 59.36          | 59.25 | 65.80          | 72.02 | 66.20          | 68.84 | 78.58          |       |
| COM + 39 | 48.94          | 51.04 | 55.17          | 58.94          | 58.88 | 65.41          | 71.62 | 65.87          | 68.55 | 78.30          |       |
| COM + 40 | 48.47          | 50.57 | 54.61          | 58.51          | 58.51 | 65.02          | 71.23 | 65.54          | 68.27 | 78.02          |       |
| COM + 41 | 48.01          | 50.10 | 54.16          | 58.10          | 58.15 | 64.63          | 70.85 | 65.21          | 67.98 | 77.74          |       |
| COM + 42 | 47.56          | 49.65 | 53.72          | 57.69          | 57.79 | 64.25          | 70.47 | 64.89          | 67.70 | 77.47          |       |
| COM + 43 | 47.11          | 49.20 | 53.28          | 57.29          | 57.44 | 63.88          | 70.09 | 64.57          | 67.42 | 77.19          |       |
| COM + 44 | 46.68          | 48.76 | 52.85          | 56.89          | 57.09 | 63.50          | 69.72 | 64.25          | 67.15 | 76.92          |       |
| COM + 45 | 46.25          | 48.33 | 52.43          | 56.50          | 56.74 | 63.14          | 69.35 | 63.94          | 66.87 | 76.65          |       |
| COM + 46 | 45.83          | 47.91 | 52.01          | 56.11          | 56.40 | 62.77          | 68.99 | 63.63          | 66.60 | 76.38          |       |
| COM + 47 | 45.42          | 47.49 | 51.60          | 55.73          | 56.06 | 62.42          | 68.62 | 63.32          | 66.33 | 76.12          |       |
| COM + 48 | 45.01          | 47.08 | 51.20          | 55.35          | 55.73 | 62.06          | 68.27 | 63.02          | 66.06 | 75.85          |       |
| COM + 49 | 44.61          | 46.68 | 50.80          | 54.98          | 55.40 | 61.71          | 67.91 | 62.71          | 65.80 | 75.59          |       |
| COM + 50 | 44.22          | 46.28 | 50.41          | 54.61          | 55.07 | 61.36          | 67.56 | 62.42          | 65.54 | 75.33          |       |

Table 3.14.9 f<sub>FP</sub> Table for Each Common Number (2/2)

| D             | 6.5   | 6.0   | 5.0   | 4.0   | 3.5   | 3.0   | 2.5   | 2.5   | 2.0   | 1.5   | Unit |
|---------------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|------|
| COM<br>number | 64    | 68    | 80    | 100   | 120   | 128   | 144   | 160   | 200   | 240   |      |
| COM + 51      | 43.84 | 45.89 | 50.03 | 54.25 | 54.75 | 61.02 | 67.22 | 62.12 | 62.27 | 75.07 |      |
| COM + 52      | 43.46 | 45.51 | 49.65 | 53.89 | 54.43 | 60.68 | 66.87 | 61.83 | 65.02 | 74.81 |      |
| COM + 53      | 43.09 | 45.13 | 49.28 | 53.54 | 54.12 | 60.35 | 66.53 | 61.54 | 64.76 | 74.56 |      |
| COM + 54      | 42.72 | 44.77 | 48.91 | 53.19 | 53.81 | 60.01 | 66.20 | 61.25 | 64.50 | 74.30 |      |
| COM + 55      | 42.36 | 44.40 | 48.55 | 52.85 | 53.50 | 59.69 | 65.87 | 60.96 | 64.25 | 74.05 |      |
| COM + 56      | 42.01 | 44.04 | 48.19 | 52.51 | 53.19 | 59.36 | 65.54 | 60.68 | 64.00 | 73.80 |      |
| COM + 57      | 41.66 | 43.69 | 47.84 | 52.18 | 52.89 | 59.04 | 65.21 | 60.40 | 63.75 | 73.55 |      |
| COM + 58      | 41.32 | 43.34 | 47.49 | 51.85 | 52.60 | 58.72 | 64.89 | 60.12 | 63.50 | 73.31 |      |
| COM + 59      | 40.99 | 43.00 | 47.15 | 51.52 | 52.30 | 58.41 | 64.57 | 59.85 | 63.26 | 73.06 |      |
| COM + 60      | 40.66 | 42.67 | 46.81 | 51.20 | 52.01 | 58.10 | 64.25 | 59.58 | 63.02 | 72.82 |      |
| COM + 61      | 40.33 | 42.34 | 46.48 | 50.88 | 51.73 | 57.79 | 63.94 | 59.31 | 62.77 | 72.58 |      |
| COM + 62      | 40.01 | 42.01 | 46.15 | 50.57 | 51.44 | 57.49 | 63.63 | 59.04 | 62.53 | 72.34 |      |
| COM + 63      | 39.69 | 41.69 | 45.83 | 50.26 | 51.16 | 57.19 | 63.32 | 58.78 | 62.30 | 72.10 |      |
| COM + 64      | 39.38 | 41.37 | 45.51 | 49.95 | 50.88 | 56.89 | 63.02 | 58.51 | 62.06 | 71.86 |      |
| COM + 65      | 39.08 | 41.06 | 45.20 | 49.65 | 50.61 | 56.59 | 62.71 | 58.25 | 61.83 | 71.62 | Hz   |
| COM + 66      | 38.78 | 40.76 | 44.89 | 49.35 | 50.33 | 56.30 | 62.42 | 58.00 | 61.59 | 71.39 | ПZ   |
| COM + 67      | 38.48 | 40.45 | 44.58 | 49.05 | 50.07 | 56.01 | 62.12 | 57.74 | 61.36 | 71.16 |      |
| COM + 68      | 38.19 | 40.16 | 44.28 | 48.76 | 49.80 | 55.73 | 61.83 | 57.49 | 61.13 | 70.93 |      |
| COM + 69      | 37.90 | 39.86 | 43.98 | 48.47 | 49.54 | 55.45 | 61.54 | 57.24 | 60.91 | 70.70 |      |
| COM + 70      | 37.62 | 39.57 | 43.69 | 48.19 | 48.28 | 55.16 | 61.25 | 56.99 | 60.68 | 70.47 |      |
| COM + 71      | 37.34 | 39.29 | 43.40 | 47.91 | 49.02 | 54.89 | 60.96 | 56.74 | 60.46 | 70.24 |      |
| COM + 72      | 37.07 | 39.01 | 43.12 | 47.63 | 48.76 | 54.61 | 60.68 | 56.50 | 60.24 | 70.02 |      |
| COM + 73      | 36.80 | 38.73 | 42.83 | 47.35 | 48.51 | 54.34 | 60.40 | 56.25 | 60.01 | 69.79 |      |
| COM + 74      | 36.53 | 38.46 | 42.56 | 47.08 | 48.26 | 54.07 | 60.12 | 56.01 | 59.80 | 69.57 |      |
| COM + 75      | 36.27 | 38.19 | 42.28 | 46.81 | 48.01 | 53.81 | 59.85 | 55.78 | 59.58 | 69.35 |      |
| COM + 76      | 36.01 | 37.93 | 42.01 | 46.55 | 47.77 | 53.54 | 59.58 | 55.54 | 59.36 | 69.13 |      |
| COM + 77      | 35.75 | 37.66 | 41.74 | 46.28 | 47.52 | 53.28 | 59.31 | 55.30 | 59.15 | 68.91 |      |
| COM + 78      | 35.50 | 37.41 | 41.48 | 46.02 | 47.28 | 53.02 | 59.04 | 55.07 | 58.94 | 68.70 |      |
| COM + 79      | 35.25 | 37.15 | 41.22 | 45.77 | 47.05 | 52.77 | 58.75 | 54.84 | 58.72 | 68.48 |      |
| COM + 80      | 35.01 | 36.90 | 40.96 | 45.51 | 46.81 | 52.51 | 58.51 | 54.61 | 58.51 | 68.27 |      |

Note: Above value is at fs = 32.768 [kHz].

Table 3.14.10 Performance Listing for Each Segment and Common Number 64-Mbit SDRAM mode 4 GRAY

|     |                   | com | 128  | 160  | 200  | 240   | 320   | 400   | 480   |      |
|-----|-------------------|-----|------|------|------|-------|-------|-------|-------|------|
| _   | D                 |     | 3    | 3    | 2    | 2     | 2     | 1     | 1     | Unit |
|     | t <sub>LP</sub>   |     | 91.6 | 76.3 | 61.0 | 45.8  | 45.8  | 30.5  | 30.5  | μS   |
| Seg |                   |     |      |      |      |       |       |       |       |      |
| 128 | tSTOP             |     | 1.22 | 1.22 | 1.22 | 1.22  | 1.22  | 1.22  | 1.22  | μS   |
|     | CPU stop rate     |     | 1.33 | 1.60 | 2.00 | 2.67  | 2.67  | 4.00  | 4.00  | %    |
| 160 | tSTOP             |     | 1.44 | 1.44 | 1.44 | 1.44  | 1.44  | 1.44  | 1.44  | μS   |
|     | CPU stop rate     |     | 1.58 | 1.89 | 2.37 | 3.16  | 3.16  | 4.73  | 4.73  | %    |
| 240 | tSTOP             |     | 2.00 | 2.00 | 2.00 | 2.00  | 2.00  | 2.00  | 2.00  | μS   |
|     | CPU stop rate     |     | 2.18 | 2.62 | 3.28 | 4.37  | 4.37  | 6.55  | 6.55  | %    |
| 320 | tSTOP             |     | 2.56 | 2.56 | 2.56 | 2.56  | 2.56  | 2.56  | 2.56  | μS   |
|     | CPU stop rate     |     | 2.79 | 3.35 | 4.19 | 5.58  | 5.58  | 8.37  | 8.37  | %    |
| 400 | tSTOP             |     | 3.11 | 3.11 | 3.11 | 3.11  | 3.11  | 3.11  | 3.11  | μS   |
|     | CPU stop rate     |     | 3.40 | 4.08 | 5.10 | 6.80  | 6.80  | 10.19 | 10.19 | %    |
| 480 | tSTOP             |     | 3.67 | 3.67 | 3.67 | 3.67  | 3.67  | 3.67  | 3.67  | μS   |
|     | CPU stop rate     |     | 4.00 | 4.81 | 6.01 | 8.01  | 8.01  | 12.01 | 12.01 | %    |
| 560 | t <sub>STOP</sub> |     | 4.22 | 4.22 | 4.22 | 4.22  | 4.22  | 4.22  | 4.22  | μS   |
|     | CPU stop rate     |     | 4.61 | 5.53 | 6.92 | 9.22  | 9.22  | 13.84 | 13.84 | %    |
| 640 | tSTOP             |     | 4.78 | 4.78 | 4.78 | 4.78  | 4.78  | 4.78  | 4.78  | μS   |
|     | CPU stop rate     |     | 5.22 | 6.26 | 7.83 | 10.44 | 10.44 | 15.66 | 15.66 | %    |

# 64-Mbit SDRAM mode 8 GRAY /16 GRAY

|     |                 | com | 128   | 160   | 200   | 240   | 320   | 400   | 480   |      |
|-----|-----------------|-----|-------|-------|-------|-------|-------|-------|-------|------|
|     | D               |     | 3     | 3     | 2     | 2     | 2     | 1     | 1     | Unit |
|     | T <sub>LP</sub> |     | 91.6  | 76.3  | 61.0  | 45.8  | 45.8  | 30.5  | 30.5  | μS   |
| seg |                 |     |       |       |       |       |       |       |       |      |
| 128 | tSTOP           |     | 2.11  | 2.11  | 2.11  | 2.11  | 2.11  | 2.11  | 2.11  | μS   |
|     | CPU stop rate   |     | 2.31  | 2.77  | 3.46  | 4.61  | 4.61  | 6.92  | 6.92  | %    |
| 160 | tstop           |     | 2.56  | 2.56  | 2.56  | 2.56  | 2.56  | 2.56  | 2.56  | μS   |
|     | CPU stop rate   |     | 2.79  | 3.35  | 4.19  | 5.58  | 5.58  | 8.37  | 8.37  | %    |
| 240 | tSTOP           |     | 3.67  | 3.67  | 3.67  | 3.67  | 3.67  | 3.67  | 3.67  | μS   |
|     | CPU stop rate   |     | 4.00  | 4.81  | 6.01  | 8.01  | 8.01  | 12.01 | 12.01 | %    |
| 320 | tSTOP           |     | 4.78  | 4.78  | 4.78  | 4.78  | 4.78  | 4.78  | 4.78  | μS   |
|     | CPU stop rate   |     | 5.22  | 6.26  | 7.83  | 10.44 | 10.44 | 15.66 | 15.66 | %    |
| 400 | tSTOP           |     | 5.89  | 5.89  | 5.89  | 5.89  | 5.89  | 5.89  | 5.89  | μS   |
|     | CPU stop rate   |     | 6.43  | 7.72  | 9.65  | 12.86 | 12.86 | 19.30 | 19.30 | %    |
| 480 | tSTOP           |     | 7.00  | 7.00  | 7.00  | 7.00  | 7.00  | 7.00  | 7.00  | μS   |
|     | CPU stop rate   |     | 7.65  | 9.18  | 11.47 | 15.29 | 15.29 | 22.94 | 22.94 | %    |
| 560 | tstop           |     | 8.11  | 8.11  | 8.11  | 8.11  | 8.11  | 8.11  | 8.11  | μS   |
|     | CPU stop rate   |     | 8.86  | 10.63 | 13.29 | 17.72 | 17.72 | 26.58 | 26.58 | %    |
| 640 | tstop           |     | 9.22  | 9.22  | 9.22  | 9.22  | 9.22  | 9.22  | 9.22  | μS   |
|     | CPU stop rate   |     | 10.07 | 12.09 | 15.11 | 20.15 | 20.15 | 30.22 | 30.22 | %    |

| SRAMI | SRAM MONOCHROME |     |      |      |      |      |      |       |       |      |  |  |
|-------|-----------------|-----|------|------|------|------|------|-------|-------|------|--|--|
|       |                 | com | 128  | 160  | 200  | 240  | 320  | 400   | 480   |      |  |  |
|       | D               |     | 3    | 3    | 2    | 2    | 2    | 1     | 1     | Unit |  |  |
|       | T <sub>LP</sub> |     | 91.6 | 76.3 | 61.0 | 45.8 | 45.8 | 30.5  | 30.5  | μS   |  |  |
| seg   |                 |     |      |      |      |      |      |       |       |      |  |  |
| 128   | tSTOP           |     | 0.89 | 0.89 | 0.89 | 0.89 | 0.89 | 0.89  | 0.89  | μS   |  |  |
|       | CPU stop rate   |     | 0.97 | 1.17 | 1.46 | 1.94 | 1.94 | 2.91  | 2.91  | %    |  |  |
| 160   | tSTOP           |     | 1.11 | 1.11 | 1.11 | 1.11 | 1.11 | 1.11  | 1.11  | μS   |  |  |
|       | CPU stop rate   |     | 1.21 | 1.46 | 1.82 | 2.43 | 2.43 | 3.64  | 3.64  | %    |  |  |
| 240   | tSTOP           |     | 1.67 | 1.67 | 1.67 | 1.67 | 1.67 | 1.67  | 1.67  | μS   |  |  |
|       | CPU stop rate   |     | 1.82 | 2.18 | 2.73 | 3.64 | 3.64 | 5.46  | 5.46  | %    |  |  |
| 320   | tSTOP           |     | 2.22 | 2.22 | 2.22 | 2.22 | 2.22 | 2.22  | 2.22  | μS   |  |  |
|       | CPU stop rate   |     | 2.43 | 2.91 | 3.64 | 4.85 | 4.85 | 7.28  | 7.28  | %    |  |  |
| 400   | tSTOP           |     | 2.78 | 2.78 | 2.78 | 2.78 | 2.78 | 2.78  | 2.78  | μS   |  |  |
|       | CPU stop rate   |     | 3.03 | 3.64 | 4.55 | 6.07 | 6.07 | 9.10  | 9.10  | %    |  |  |
| 480   | tSTOP           |     | 3.33 | 3.33 | 3.33 | 3.33 | 3.33 | 3.33  | 3.33  | μS   |  |  |
|       | CPU stop rate   |     | 3.64 | 4.37 | 5.46 | 7.28 | 7.28 | 10.92 | 10.92 | %    |  |  |
| 560   | tSTOP           |     | 3.89 | 3.89 | 3.89 | 3.89 | 3.89 | 3.89  | 3.89  | μS   |  |  |
|       | CPU stop rate   | ·   | 4.25 | 5.10 | 6.37 | 8.50 | 8.50 | 12.74 | 12.74 | %    |  |  |
| 640   | tSTOP           | ·   | 4.44 | 4.44 | 4.44 | 4.44 | 4.44 | 4.44  | 4.44  | μS   |  |  |
|       | CPU stop rate   |     | 4.85 | 5.83 | 7.28 | 9.71 | 9.71 | 14.56 | 14.56 | %    |  |  |

# SRAM 4 GRAY

|     |                 | com | 128  | 160   | 200   | 240   | 320   | 400   | 480   |      |
|-----|-----------------|-----|------|-------|-------|-------|-------|-------|-------|------|
| _   | D               |     | 3    | 3     | 2     | 2     | 2     | 1     | 1     | Unit |
|     | T <sub>LP</sub> |     | 91.6 | 76.3  | 61.0  | 45.8  | 45.8  | 30.5  | 30.5  | μS   |
| seg |                 |     |      |       |       |       |       |       |       |      |
| 128 | tSTOP           |     | 1.78 | 1.78  | 1.78  | 1.78  | 1.78  | 1.78  | 1.78  | μS   |
|     | CPU stop rate   |     | 1.94 | 2.33  | 2.91  | 3.88  | 3.88  | 5.83  | 5.83  | %    |
| 160 | tSTOP           |     | 2.22 | 2.22  | 2.22  | 2.22  | 2.22  | 2.22  | 2.22  | μS   |
|     | CPU stop rate   |     | 2.43 | 2.91  | 3.64  | 4.85  | 4.85  | 7.28  | 7.28  | %    |
| 240 | tSTOP           |     | 3.33 | 3.33  | 3.33  | 3.33  | 3.33  | 3.33  | 3.33  | μS   |
|     | CPU stop rate   |     | 3.64 | 4.37  | 5.46  | 7.28  | 7.28  | 10.92 | 10.92 | %    |
| 320 | tSTOP           |     | 4.44 | 4.44  | 4.44  | 4.44  | 4.44  | 4.44  | 4.44  | μS   |
|     | CPU stop rate   |     | 4.85 | 5.83  | 7.28  | 9.71  | 9.71  | 14.56 | 14.56 | %    |
| 400 | tSTOP           |     | 5.56 | 5.56  | 5.56  | 5.56  | 5.56  | 5.56  | 5.56  | μS   |
|     | CPU stop rate   |     | 6.07 | 7.28  | 9.10  | 12.14 | 12.14 | 18.20 | 18.20 | %    |
| 480 | tSTOP           |     | 6.67 | 6.67  | 6.67  | 6.67  | 6.67  | 6.67  | 6.67  | μS   |
|     | CPU stop rate   |     | 7.28 | 8.74  | 10.92 | 14.56 | 14.56 | 21.85 | 21.85 | %    |
| 560 | tSTOP           |     | 7.78 | 7.78  | 7.78  | 7.78  | 7.78  | 7.78  | 7.78  | μS   |
|     | CPU stop rate   |     | 8.50 | 10.19 | 12.74 | 16.99 | 16.99 | 25.49 | 25.49 | %    |
| 640 | tSTOP           |     | 8.89 | 8.89  | 8.89  | 8.89  | 8.89  | 8.89  | 8.89  | μS   |
|     | CPU stop rate   |     | 9.71 | 11.65 | 14.56 | 19.42 | 19.42 | 29.13 | 29.13 | %    |

| SRAM 8 | SRAM 8 GRAY/16 GRAY |     |       |       |       |       |       |       |       |      |  |  |
|--------|---------------------|-----|-------|-------|-------|-------|-------|-------|-------|------|--|--|
|        |                     | com | 128   | 160   | 200   | 240   | 320   | 400   | 480   |      |  |  |
|        | D                   |     | 3     | 3     | 2     | 2     | 2     | 1     | 1     | Unit |  |  |
|        | T <sub>LP</sub>     |     | 91.6  | 76.3  | 61.0  | 45.8  | 45.8  | 30.5  | 30.5  | μS   |  |  |
| seg    |                     |     |       |       |       |       |       |       |       |      |  |  |
| 128    | tSTOP               |     | 3.56  | 3.56  | 3.56  | 3.56  | 3.56  | 3.56  | 3.56  | μS   |  |  |
|        | CPU stop rate       |     | 3.88  | 4.66  | 5.83  | 7.77  | 7.77  | 11.65 | 11.65 | %    |  |  |
| 160    | tSTOP               |     | 4.44  | 4.44  | 4.44  | 4.44  | 4.44  | 4.44  | 4.44  | μS   |  |  |
|        | CPU stop rate       |     | 4.85  | 5.83  | 7.28  | 9.71  | 9.71  | 14.56 | 14.56 | %    |  |  |
| 240    | tSTOP               |     | 6.67  | 6.67  | 6.67  | 6.67  | 6.67  | 6.67  | 6.67  | μS   |  |  |
|        | CPU stop rate       |     | 7.28  | 8.74  | 10.92 | 14.56 | 14.56 | 21.85 | 21.85 | %    |  |  |
| 320    | tSTOP               |     | 8.89  | 8.89  | 8.89  | 8.89  | 8.89  | 8.89  | 8.89  | μS   |  |  |
|        | CPU stop rate       |     | 9.71  | 11.65 | 14.56 | 19.42 | 19.42 | 29.13 | 29.13 | %    |  |  |
| 400    | tSTOP               |     | 11.11 | 11.11 | 11.11 | 11.11 | 11.11 | 11.11 | 11.11 | μS   |  |  |
|        | CPU stop rate       |     | 12.14 | 14.56 | 18.20 | 24.27 | 24.27 | 36.41 | 36.41 | %    |  |  |
| 480    | tSTOP               |     | 13.33 | 13.33 | 13.33 | 13.33 | 13.33 | 13.33 | 13.33 | μS   |  |  |
|        | CPU stop rate       |     | 14.56 | 17.48 | 21.85 | 29.13 | 29.13 | 43.69 | 43.69 | %    |  |  |
| 560    | tSTOP               |     | 15.56 | 15.56 | 15.56 | 15.56 | 15.56 | 15.56 | 15.56 | μS   |  |  |
|        | CPU stop rate       |     | 16.99 | 20.39 | 25.49 | 33.98 | 33.98 | 50.97 | 50.97 | %    |  |  |
| 640    | tSTOP               |     | 17.78 | 17.78 | 17.78 | 17.78 | 17.78 | 17.78 | 17.78 | μS   |  |  |
|        | CPU stop rate       |     | 19.42 | 23.30 | 29.13 | 38.84 | 38.84 | 58.25 | 58.25 | %    |  |  |

over 50%

- Note 1: The value of the Table 3.14.8 is at  $f_C = 36$  [MHz].
- Note 2: Bus occupation time to CPU; t<sub>STOP</sub> (in the Figure 3.14.11) is the time which CPU reads the memory of transferring with 0 waits.

Note 3: The following equation can calculate  $t_{LP}$  listed below.

 $t_{LP} = D/32768$  [s] (e.g.) If the row is 240 and D = 1.5 by the above table



Figure 3.14.11 Bus occupation time to CPU and BUS Occupation Rate of CPU

#### 3.14.4.6 Timing Charts of Interpreting Memory Codes

TMP91C820A supports different memory accessing. They are SRAM with waits, SDRAM burst modes, and the size of SDRAM is 16M/64M/128Mbits. The access signals for the LCD panel are shown in Figure 3.14.12. To catch low speed LCD drivers, 3 types of SCP rates (fsys/2, fsys/4, and fsys/8) can be selected. The output data (LD7 to LD0) will be issued from the built-in FIFO at the rising edge of D1BSCP when the FIFO is no empty. The work of the FIFO is illustrated in Figure 3.14.13, where the buffer size 80 bytes. The FIFO latches BaseLD7 to LD0 signal at the falling edge of BaseSCP which is shown in Figure 3.14.14 and 3.14.15 for SRAM and SDRAM modes respectively. The FIFO is always reset to the empty state by the rising edge of D2BLP. In BaseSCP mode (e.g., for SCPW1, 0 = 00), D1BCP is equal to BaseSCP, LD7 to LD0 equal to BaseLD7 to LD0 and no FIFO used. Generally, the data input rate of FIFO should be greater than the output one.

To make FIFO work correctly, the following condition have to be satisfied by setting SFR properly.

$$(N/8 + 1) \times tcw + 24 \times 1/f_C < t_{LP} - t_{LPH}$$

Here, N is the segment number, and tow is D1BSCP clock cycle,  $t_{LP}$  is D2BLP cycle, and  $t_{LPH}$  is High width of D2BLP signal. Referring Figure 3.14.16, we can know this relation means that the last LD7 to LD0 data must be generated before the rising edge of D2BLP.

For example, in case of  $f_C = 36$  MHz,  $f_S = 32$  kHz, 4 gray, 240 com, 640 seg, and SDRAM burst mode, the following table can be obtained, which tells user that 8 clock mode is impossible and SCPW = base/2/4 clock modes can be used.

| SCPW  | D1BSCP<br>frequency<br>(MHz) | tcw (ns) | (N/8+1) × tcw + T_busdly<br>+ T_busfmax (ns) | t <sub>LP</sub> – t <sub>LPH</sub> (ns) | Judgment |
|-------|------------------------------|----------|----------------------------------------------|-----------------------------------------|----------|
| Base  | 18                           | 55.6     | 5166.1                                       | 31250                                   | OK       |
| 2 clk | 9                            | 111.2    | 9674.4                                       | 31250                                   | OK       |
| 4 clk | 4.5                          | 222.4    | 18681.6                                      | 31250                                   | OK       |
| 8 clk | 2.25                         | 444.8    | 36696                                        | 31250                                   | ERROR    |

Note: The speed of BaseSCP mode is equal to 2clk mode in the 8 or 16 GRAY mode.



Figure 3.14.12 Timing Diagram for the LCD Panel Access Signals



Note: D1BSCP = BaseSCP and BaseLD7 to LD0 = BaseLD7 to LD0 in BaseSCP mode (e.g., for SCPW [1:0] = 00)

Figure 3.14.13 Timing Diagram for FIFO



Figure 3.14.14 Timing Diagram for SRAM Mode with BaseSCP



Figure 3.14.15 Timing Diagram for SDRAM BURST Mode with BaseSCP



Note 1: If Base SCP, T\_bufmax = 0.

Note 2: If except Base,  $T_bufmax \le tcw + 2/fc$ 

Note 3: T\_busdly is about 11 times as long as fSYS period (22/fc).

Figure 3.14.16 Timing Diagram for Maximum FIFO Delay Time

#### 3.14.4.7 Interface Examples at SR Mode



Note 1: Display memory should be 16-bit bus.

Note 2: Other circuit is necessary for LCD drive power supply for LCD driver display.

Figure 3.14.17 Interface Example for Shift Register Type LCD Driver

Note: Because the connection between the line of display RAM data and output bus: LD0:7 is just the mirror reverse, please care of connection. The data LSB of display RAM is output from LD7. In the above figure, LD0 should be connected to DI7 of LCD driver, and LD1 to DI6.

For detail information, please refer to Figure 3.14.5.

# 3.14.4.8 Sample Program

• Example:

In case of use  $240 \text{ SEG} \times 240 \text{ COM}$ , 4-level gray scale display, 64-Mbit SDRAM. This sample program operate correctly, LCD panel shows Figure 3.14.18 display.

```
;**** SDRAM SET ****
        LD
                 (sdacr), 2bH
                                  ; Add-MUX enable, 64-Mbit select
                 (sdrcr), 01H
        LD
                                  ; Interval refresh
;***** GLCDC SET *****
        LD
                 (lcdmode), 17H
                                  ; A/B area off, SDRAM 64 Mbits, SR type
                                  ; SCP width 2 clocks
        LD
                 (lcddvm), 11
                                  ; 11-count DVM set
        LD
                 (lcdsize), 32H
                                  ; COM = 240, SEG = 240
        LD
                 (lcdctl), 20H
                                  ; Divide frame ON, display OFF
                 (lcdffp), 240
        LD
                                  ; Frame frequency correction (91 Hz)
        LD
                 (lcdgl), 01h
                                  ; 4-level gray
        LD
                 (lcdcm), 0c1H
                                  ; Cursor ON, black, 2 Hz blink
        LD
                 (lcdcw), 19
                                  Width = 20 dots
                 (lcdch), 19
                                  ; Height = 20 dots
        LD
        LD
                 (lcdcp), 00H
                                  ; Pixel = 0
        LD
                 (lcdcpl), 00H
                                  ; Cursor position
        LD
                 (lcdcpm), 00H
                                  ; Cursor address
        LD
                 (lcdcph), 40H
                                  ; Cursor address
        LD
                 (lsarch), 40H
                                  ; C_area start address
        LD
                 (lsarcm), 00H
                                  ; C_area start address
        LD
                 (lsarcl), 00H
                                  ; C_area start address
;***** 0/4 data write 60 ROW *****
        LD
                 xix, 400000H
                                  LD
                 wa, 0000H
loop1:
        LD
                 (xix), wa
        INC
                 2, xix
        CP
                                  ; 400000H to 4077FFH: 60 ROW (Dot)
                 xix, 407800H
                 nz, loop1
        JR
;**** 2/4 data write 60 ROW *****
        LD
                 xix, 407800H
        LD
                 wa, 05555H
                                  ; Write data 2/4 gray data (0101010101010101b)
                 (xix), wa
loop2:
        LD
        INC
                 2. xix
        CP
                 xix, 40F000H
                                  ; 407800H to 40EFFFH: 60 ROW (Dot)
        JR
                 nz, loop2
```

```
;**** 3/4 data write 60 ROW *****
         LD
                  xix, 40F000H
        LD
                  wa, 0aaaaH
                                    ; Write data 3/4 gray data (1010101010101010b)
loop3:
        LD
                  (xix), wa
         INC
                  2, xix
         CP
                  xix, 416800H
                                    ; 40F000H to 4167FFH: 60 ROW (Dot)
         JR
                  nz, loop3
;**** 4/4 data write 60 ROW *****
         LD
                  xix, 416800H
         LD
                  wa, 0ffffH
                                    ; Write data 4/4 gray data (111111111111111b)
loop4:
        LD
                  (xix), wa
         INC
                  2, xix
         CP
                  xix, 41e000H
                                    ; 416800H to 41DFFFH: 60 ROW (Dot)
         JR
                  nz, loop4
;**** 4-level gray palette pattern set ****
                  (lg0l), 00H
         LD
                                    ; 0/4 gray scale palette 0000b
         LD
                  (lg1l), 05H
                                    ; 2/4 gray scale palette 0101b
                  (lg2l), 0eH
                                    ; 3/4 gray scale palette 1110b
         LD
                  (lg31), 0fH
         LD
                                    ; 4/4 gray scale palette 1111b
;***** DMA, DISPLAY-ON start *****
         LD
                  (lcdctl), 0a1H
                                    ; Display on, divide on
```



Figure 3.14.18 Display Reference above Sample Program

#### 3.14.5 RAM Built-in Type LCD Driver Control Mode (RAM type)

#### 3.14.5.1 Operation

Data transmission to LCD driver is executed by move instruction of CPU.

After setting mode of operation to SFR, when move instruction of CPU is executed LCDC outputs chip select signal to LCD driver connected to the outside from control pin (D1BSCP etc.). Therefore control of data transmission numbers corresponding to LCD size is controlled by instruction of CPU. There are 2 kinds of address of LCD driver in this case, and which is chosen determines by LCDCTL <MMULCD> register.

It corresponds to LCD driver which has every 1 byte of instruction register and display data register in LCD driver at the time of <MMULCD> = "0". Please make the transmission place address at this time into either of FE0H to FE7F. (SEQUENTIAL ACCESS TYPE: See Table 3.14.3)

It corresponds to address direct writing type LCD driver at the time of <MMULCD> = "1".

The transmission place address at this time can also assign the memory area of 3C0000H to 3FFFFFH to four area for every 64 Kbytes. (RANDOM ACCESS TYPE: See Table 3.14.4)



Figure 3.14.19 Example of Access Timing for RAM Built-in Type LCD Driver (Wait = 0)

# 3.14.5.2 Interface Examples at Internal RAM Mode



Note: Other circuit is necessary for LCD drive power supply for LCD driver display.

Figure 3.14.20 Interface Example for RAM Built-in Type Sequential Access Type LCD DRIVER

**TOSHIBA** 

# 3.14.5.3 Sample Program

• Example: In case of use 80SEG × 65COM LCD driver.

Assign external column driver to LCDC1 and row driver to LCDC4.

This example used LD instruction in setting of instruction and used burst function of micro DMA in transmitting of display data.

# In case of store 650 bytes transfer data to LCD driver.

```
; ***** Setting external terminal *****
        LD
                  (pdcr), 19H
                                    ; \overline{\text{CE}} for LCDC1:D1BSCP,
                                    ; LE for LCDL1:DLEBCD,
                                    ; Setting for \overline{\text{DOFF}}
; ***** Setting for LCDC *****
        LD
                  (lcdmode), 00H
                                    ; Select RAM mode
        LD
                  (lcdctl), 00H
                                    ; MMULCD = 0 (Sequential access mode)
; ***** Setting for mode of LCDC0/LCDR0 *****
        LD
                  (lcdc1l), xx
                                    ; Setting instruction for LCDC1
        LD
                  (lcdc4l), xx
                                    ; Setting instruction for LCDC4
;**** Setting for micro DMA and INTTC (ch 0) *****
        LD
                  a. 08H
                                    ; Source address INC mode
        LDC
                  dmam0, a
        LD
                  wa, 650
                                    ; Count = 650
        LDC
                  dmac0, wa
        LD
                  xwa, 1000H
                                    ; Source address = 1000H
        LDC
                  dmas0, xwa
                                    ; Destination address = FE1H (LCDC0H)
        LD
                  xwa, 0fe1H
        LDC
                  dmad0, xwa
        LD
                  (intetc01), 06H
                                    ; INTTC0 level = 6
        EI
```

; Burst mode

; Soft start

(dmab), 01H

(dmar), 01H

LD

LD

# 3.15 Melody/Alarm Generator (MLD)

TMP91C820A incorporates melody function and alarm function, both of which are output from the MLDALM pin. Five kind of fixed cycles interrupt is generate by using 15-bit counter, which is used for alarm generator.

Features are as follows.

#### • Melody generator

The melody function generates signals of any frequency (4 Hz to 5461 Hz) based on low-speed clock (32.768 kHz) and outputs the signals from the MLDALM pin.

By connecting a loud speaker outside, melody tone can easily sound.

#### • Alarm generator

The Alarm function generates eight kinds of alarm waveform having a modulation frequency (4096 Hz) determined by the low-speed clock (32.768 kHz). And this waveform is able to invert by setting a value to a register.

By connecting a loud speaker outside, alarm tone can easily sound.

Five kind of fixed cycles (1 Hz, 2 Hz, 64 Hz, 512 Hz, 8192 Hz) interrupts be generated by using a counter which is used for alarm generator.

#### • Special mode

It is assigned <TA3LCDE> at bit0 and <TA3MLDE> at bit1, of EMCCR0 register (00E7hex). These bits are used when you want to operate LCDC and MELODY circuit without low-frequency clock (XTIN, XTOUT). After reset these two bits set to 0 and low clock is supplied each LCDC and MELODY circuit. If you write these bits to 1, TA3 (Generate by timer 3) is supplied each LCDC and MELODY circuit. In this case, you should set 32 kHz timer 3 frequency. For detail, look AC specification characteristics.

This section is constituted as follows.

- 3.15.1 Block Diagram
- 3.15.2 Control Registers
- 3.15.3 Operational Description
  - 3.15.3.1 Melody Generator
  - 3.15.3.2 Alarm Generator

# 3.15.1 Block Diagram



Figure 3.15.1 MLD Block Diagram

# 3.15.2 Control Registers

# ALM R Register

ALM (0330H)

|             | 7   | 6                     | 5   | 4   | 3   | 2   | 1   | 0   |  |  |  |
|-------------|-----|-----------------------|-----|-----|-----|-----|-----|-----|--|--|--|
| Bit symbol  | AL8 | AL7                   | AL6 | AL5 | AL4 | AL3 | AL2 | AL1 |  |  |  |
| Read/Write  |     | R/W                   |     |     |     |     |     |     |  |  |  |
| After reset |     |                       |     | C   | )   |     |     |     |  |  |  |
| Function    |     | Setting alarm pattern |     |     |     |     |     |     |  |  |  |

# MELALMC Register

MELALMC (0331H)

|    |             | 7                                                                             | 6   | 5                                        | 4   | 3                 | 2   | 1   | 0      |
|----|-------------|-------------------------------------------------------------------------------|-----|------------------------------------------|-----|-------------------|-----|-----|--------|
| ΛС | Bit symbol  | FC1                                                                           | FC0 | ALMINV                                   | -   | -                 | -   | -   | MELALM |
|    | Read/Write  | R/W                                                                           |     | R/W                                      | R/W | R/W               | R/W | R/W | R/W    |
|    | After reset | 0 Free-run counter control 00: Hold 01: Restart 10: Clear 11: Clear and start |     | 0                                        | 0   | 0                 | 0   | 0   | 0      |
|    | Function    |                                                                               |     | Alarm<br>waveform<br>invert<br>1: Invert |     | Always write "0". |     |     |        |

Note 1: MELALMC<FC1> is read always 0.

Note 2: When setting MELALMC register except <FC1:0> during the free-run counter is running, <FC1:0> is kept 01.

# MELFL Register

MELFL (0332H)

|             | 7                              | 6                                       | 5 | 4 | 3 | 2 | 1 | 0 |  |  |
|-------------|--------------------------------|-----------------------------------------|---|---|---|---|---|---|--|--|
| Bit symbol  | pol ML7 ML6 ML5 ML4 ML3 ML2 ML |                                         |   |   |   |   |   |   |  |  |
| Read/Write  |                                | RW                                      |   |   |   |   |   |   |  |  |
| After reset |                                |                                         |   | C | ) |   |   |   |  |  |
| Function    |                                | Setting melody frequency (Lower 8 bits) |   |   |   |   |   |   |  |  |

# MELFH Register

MELFH (0333H)

|             | 7                                                                   | 6 | 5                             | 4 | 3        | 2    | 1   | 0       |
|-------------|---------------------------------------------------------------------|---|-------------------------------|---|----------|------|-----|---------|
| Bit symbol  | MELON                                                               |   |                               |   | ML11     | ML10 | ML9 | ML8     |
| Read/Write  | R/W                                                                 |   |                               |   | R/W<br>0 |      |     |         |
| After reset | 0                                                                   |   |                               |   |          |      |     |         |
| Function    | Control<br>melody<br>counter<br>0: Stop<br>and<br>clear<br>1: Start |   | Setting melody frequency (Upp |   |          |      |     | 4 bits) |

# ALMINT Register

ALMINT (0334H)

|             | 7 | 6 | 5                    | 4                                          | 3      | 2      | 1      | 0      |  |  |
|-------------|---|---|----------------------|--------------------------------------------|--------|--------|--------|--------|--|--|
| Bit symbol  |   |   | -                    | IALM4E                                     | IALM3E | IALM2E | IALM1E | IALM0E |  |  |
| Read/Write  |   |   | R/W                  | R/W                                        |        |        |        |        |  |  |
| After reset |   |   | 0                    | 0                                          |        |        |        |        |  |  |
| Function    |   |   | Always<br>write "0". | 1: Interrupt enable for INTALM4 to INTALM0 |        |        |        |        |  |  |

# 3.15.3 Operational Description

#### 3.15.3.1 Melody Generator

The melody function generates signals of any frequency (4 Hz to 5461 Hz) based on low-speed clock (32.768 kHz) and outputs the signals from the MLDALM pin.

By connecting a loud speaker outside, melody tone can easily sound.

#### (Operation)

At first, MELALMC<MELALM> have to be set as 1 in order to select melody waveform as output waveform from MLDALM. Then melody output frequency has to be set to 12-bit register MELFH, MELFL.

Followings are setting example and calculation of melody output frequency.

(Formula for calculating of melody waveform frequency)

at fs = 32.768 [kHz]

melody output waveform  $f_{MLD}$  [Hz] =  $32768/(2 \times N + 4)$ 

setting value for melody  $N = (16384/f_{MLD}) - 2$ 

(Notice: N = 1 to 4095 (001H to FFFH), 0 is not acceptable)

## (Example program)

In case of outputting a musical scale (440 Hz)

LD (MELALMC), 11X00001B ; Select melody waveform

LD (MELFL), 23H ; N = 16384/440 - 2 = 35.2 = 023H

LD (MELFH), 80H ; Start to generate waveform

# (Ref: Basic musical scale setting table)

| Scale | Frequency | Register |  |  |
|-------|-----------|----------|--|--|
| Scale | [Hz]      | Value: N |  |  |
| С     | 264       | 03CH     |  |  |
| D     | 297       | 035H     |  |  |
| Е     | 330       | 030H     |  |  |
| F     | 352       | 02DH     |  |  |
| G     | 396       | 027H     |  |  |
| Α     | 440       | 023H     |  |  |
| В     | 495       | 01FH     |  |  |
| С     | 528       | 01DH     |  |  |

#### 3.15.3.2 Alarm Generator

The alarm function generates eight kinds of alarm waveform having a modulation frequency 4096 Hz determined by the low-speed clock (32.768 kHz). And this waveform is reversible by setting a value to a register.

By connecting a loud speaker outside, alarm tone can easily sound.

Five kind of fixed cycles (1 Hz, 2 Hz, 64 Hz, 512 Hz, 8 kHz) INTERRUPT be generated by using a counter which is used for alarm generator.

#### (Operation)

At first, MELALMC<MELALM> have to be set as 0 in order to select alarm waveform as output waveform from MLDALM. Then 10 be set on MELALMC<FC1:0> register, and clear internal counter. Finally alarm pattern has to be set on 8-bit register of ALM. If it is inverted output-data, set <ALMINV> as invert.

Followings are example program, setting value of alarm pattern and waveform of each setting value.

(Setting value of alarm pattern)

| Setting Value<br>for ALM<br>Register | Alarm Waveform |
|--------------------------------------|----------------|
| 00H                                  | 0 fixed        |
| 01H                                  | AL1 pattern    |
| 02H                                  | AL2 pattern    |
| 04H                                  | AL3 pattern    |
| 08H                                  | AL4 pattern    |
| 10H                                  | AL5 pattern    |
| 20H                                  | AL6pattern     |
| 40H                                  | AL7 pattern    |
| 80H                                  | AL8 pattern    |
| Other                                | Undefined      |
|                                      | (Do not set.)  |

#### (Example program)

In case of outputting AL2 pattern (31.25 ms/8 times/1 s)

LD (MELALMC), C0H ; Set output alarm waveform

; Free-run counter start

LD (ALM), 02H ; Set AL2 pattern, start

Example: Waveform of alarm pattern for each setting value (Not invert).



# 3.16 SDRAM Controller (SDRAMC)

TMP91C820A includes SDRAM controller which supports data access by CPU/LCDC. The features are as follows.

# (1) Support SDRAM

16- or 64- or 128-Mbit SDRAM (× 16 bits × 2/4 BANKs), not support DDR

#### (2) Automatic initialize function

- All BANK pre-charge command generate
- Mode register set generate
- 8 times auto refresh

#### (3) Access mode

|                     | CPU Access   | LCDC Access |  |  |
|---------------------|--------------|-------------|--|--|
| Burst length        | 1 word       | Full page   |  |  |
| Addressing mode     | Sequential   | Sequential  |  |  |
| CAS latency (Clock) | 2            | 2           |  |  |
| Write mode          | Single write | -           |  |  |

#### (4) Access cycle

• CPU access (Read/write)

Read cycle: 4 states (222 ns at 36 MHz) Write cycle: 3 states (167 ns at 36 MHz)

Access data width: 8 bits/16 bits

Burst length: 1 word only

• LCDC burst access (Read only)

Read cycle: 1 state (55 ns at 36 MHz) Overhead: 4 states (222 ns at 36 MHz)

Access data width: 16 bits only Burst length: Full page only

#### (5) Refresh cycle auto generate

- Auto refresh is generated during another area access.
- Refresh interval is programmable.
- Self refresh is supported

#### Notes:

- Display data has to set from the head of each page.
- Program is not operated on SDRAM.
- Following condition is set by setting Chip select controller CS1.
  - WAIT setting: 0 WAIT setting only
  - Bus width: 8/16 bit only
  - Memory area: Optional

# 3.16.1 Control Registers

Figure 3.16.1 shows the SDRAMC control registers. Setting these registers controls the operation of SDRAMC.

# SDRAM Access Control Register

SDACR (04F0H)

|             | 7                                             | 6                                    | 5           | 4        | 3                                               | 2                                                                       | 1      | 0                                     |
|-------------|-----------------------------------------------|--------------------------------------|-------------|----------|-------------------------------------------------|-------------------------------------------------------------------------|--------|---------------------------------------|
| Bit symbol  | SDINI                                         | SWRC                                 | -           | -        | SMUXE                                           | SMUXW1                                                                  | SMUXW0 | SMAC                                  |
| Read/Write  | R/W                                           | R/W                                  | R/W         | R/W      | R/W                                             | R/                                                                      | R/W    |                                       |
| After reset | 0                                             | 0                                    | 1           | 0        | 0                                               | 0                                                                       | 0      | 0                                     |
| Function    | Auto<br>initialize<br>0: Disable<br>1: Enable | Write recovery 0: 1 clock 1: 2 clock | Always writ | te "10". | Address<br>multiplex<br>0: Disable<br>1: Enable | SDRAM select<br>00: 16 Mbits 10: 128 Mbits<br>01: 64 Mbits 11: Reserved |        | SDRAM controller 0: Disable 1: Enable |

# SDRAM Refresh Control Register

SDRCR (04F1H)

|             |                                        |                                                                                 |                |      | 3                    |   |   |                                            |
|-------------|----------------------------------------|---------------------------------------------------------------------------------|----------------|------|----------------------|---|---|--------------------------------------------|
|             | 7                                      | 6                                                                               | 5              | 4    | 3                    | 2 | 1 | 0                                          |
| Bit symbol  | SFRC                                   | SRS2                                                                            | SRS1           | SRS0 | -                    |   |   | SRC                                        |
| Read/Write  | R/W                                    |                                                                                 | R/W            |      | R/W                  |   |   | R/W                                        |
| After reset | 0                                      | 0                                                                               | 0              | 0    | 0                    |   |   | 0                                          |
| Function    | Self<br>refresh<br>0: Exit<br>1: Entry | Auto refres<br>000: 78 state<br>001: 97 state<br>010:124 state<br>011:156 state | th interval 25 |      | Always<br>write "0". |   |   | Auto<br>refresh<br>0: Disable<br>1: Enable |

Figure 3.16.1 SDRAMC Control Registers

Self refresh operation is controlled by setting SDRCR<SFRC>, and self-refresh mode become Entry by writing "1" to it. If wrote "0" to SDRCR<SFRC>, Self refresh mode become Exit.

# 3.16.2 Operation Description

#### (1) Memory access control

The SDRAMC is enabled by setting SDACR<SMAC> to "1".

When one of the bus masters (CPU, LCDC) generates a cycle to access the SDRAM address area, the SDRAMC outputs SDRAM control signals (SDCS, SDRAS, SDCAS, SDWE, SDLDQM, SDUDQM, SDCLK, SDCKE).

In the access cycle, address multiplex outputs row/column multiplex address through A1 to A12 pin. And multiplex width is decided by setting SDACR<SMUXW1:0>. The relation between multiplex width and memory size is Table 3.16.1.

| SDRAM    | TN                        | лР91С820A | Address Outp | out              |               |
|----------|---------------------------|-----------|--------------|------------------|---------------|
| Address  | Column                    |           | Row Address  | 3                |               |
| Pin Name | Address                   | 16 Mbits  | 64 Mbits     | 128 Mbits        | ← Memory size |
| -        | A0                        | A0        | A0           | A0               |               |
| A0       | A1                        | A9        | A9           | A10              |               |
| A1       | A2                        | A10       | A10          | A11              |               |
| A2       | А3                        | A11       | A11          | A12              |               |
| А3       | A4                        | A12       | A12          | A13              |               |
| A4       | A5                        | A13       | A13          | A14              |               |
| A5       | A6                        | A14       | A14          | A15              |               |
| A6       | A7                        | A15       | A15          | A16              |               |
| A7       | A8                        | A16       | A16          | A17              |               |
| A8       | A9                        | A17       | A17          | A18              |               |
| A9       | A10                       | A18       | A18          | A19              |               |
| A10      | A11                       | A19       | A19          | A20              |               |
| A11      | A12                       |           | A20          | A21              |               |
| BS0      | A13                       | A20       | A21          | A22              |               |
| BS1      | A14                       |           | A22          | A23              |               |
| TMPod    | ↑<br>0000 A = 4 H = 2 = 2 |           |              | Effective column | n address     |

Table 3.16.1 Address Multiplex

SDRAM access by CPU is performed by the 1 word burst mode.

SDRAM access by LCDC is performed by 1 page burst mode.

TMP91C820A address pin name

SDRAM access cycle is shown in Figure 3.16.2 to Figure 3.16.7.

The read cycle by CPU is the 4-state fixation, and a write cycle is the 3-state fixation.

In the burst read cycle by LCDC, a mode register setup, a pre-charge cycle, and a refresh cycle are automatically inserted in CPU cycle front and back.

Note: In SDRAM access cycle, WAIT setup by the CS/WAIT controller (CS1) is disregarded. The wait setting of CS1 should be 0 waits.



Figure 3.16.2 SDRAM Access Timing (CPU read)



Figure 3.16.3 SDRAM Access Timing (CPU write 16 bits)



Figure 3.16.4 SDRAM Access Timing (CPU write 16 bits, write recovery: 2 clocks)



Figure 3.16.5 SDRAM Access Timing (CPU lower byte write)



Figure 3.16.6 SDRAM Access Timing (CPU upper byte write)



Figure 3.16.7 SDRAM Access Timing (LCDC burst read)

#### (2) Refresh control

The TMP91C820A supports Auto Refresh cycle.

When SDRCT<SRC> is set to "1", the Auto Refresh cycle is automatically generate at intervals specified by SDRCR<SRS2:0>. The Auto Refresh interval can be specified in a range of 78 states to the 312 states (4.3 µs to 17.3 µs at 36 MHz).

The generating timing of a refresh cycle becomes into access cycles other than SDRAM area (CS1) after the interval setup by <SRS2:0>.

The refresh cycle is shown in Figure 3.16.8. Moreover, the refreshment interval is shown in Table 3.16.2.



Figure 3.16.8 Refresh Cycle

| Table 3.16.2 | Auto Refres | sh Cycle | Insertion | Interval |
|--------------|-------------|----------|-----------|----------|
|--------------|-------------|----------|-----------|----------|

(Unit: μs)

| <s< th=""><th colspan="3"><srs2:0> setting</srs2:0></th><th colspan="6">Frequency (f<sub>SYS</sub>)</th></s<> | <srs2:0> setting</srs2:0> |      |                     | Frequency (f <sub>SYS</sub> ) |          |       |        |          |       |
|---------------------------------------------------------------------------------------------------------------|---------------------------|------|---------------------|-------------------------------|----------|-------|--------|----------|-------|
| SRS2                                                                                                          | SRS1                      | SRS0 | interval<br>(State) | 5 MHz                         | 6.25 MHz | 8 MHz | 10 MHz | 12.5 MHz | 18MHz |
| 0                                                                                                             | 0                         | 0    | 78                  | 15.6                          | 12.5     | 9.8   | 7.8    | 6.2      | 4.3   |
| 0                                                                                                             | 0                         | 1    | 97                  | 19.4                          | 15.5     | 12.1  | 9.7    | 7.8      | 5.4   |
| 0                                                                                                             | 1                         | 0    | 124                 | 24.8                          | 19.8     | 15.5  | 12.4   | 9.9      | 6.9   |
| 0                                                                                                             | 1                         | 1    | 156                 | 31.2                          | 25.0     | 19.5  | 15.6   | 12.5     | 8.7   |
| 1                                                                                                             | 0                         | 0    | 195                 | 39.0                          | 31.2     | 24.4  | 19.5   | 15.6     | 10.8  |
| 1                                                                                                             | 0                         | 1    | 210                 | 42.0                          | 33.6     | 26.3  | 21.0   | 16.8     | 11.7  |
| 1                                                                                                             | 1                         | 0    | 247                 | 49.4                          | 39.5     | 30.9  | 24.7   | 19.8     | 13.7  |
| 1                                                                                                             | 1                         | 1    | 312                 | 62.4                          | 49.9     | 39.0  | 31.2   | 25.0     | 17.3  |

It does not generate interval refreshment during the burst access to SDRAM by LCDC.

The interval refreshment demand generated in the meantime is held only once. When it returns to CPU access cycle, an interval refresh cycle is generated.

Furthermore, TMP91C820A can generate a self refresh cycle. The timing of a self refresh cycle is shown in Figure 3.16.9.



Figure 3.16.9 Self Refresh Cycle

Note 1: SDCLK is output in the IDLE2 mode. Therefore if you stop SDCLK, change PF6 pin to output port before the HALT instruction.

Note 2: Pin condition under the IDLE1/STOP mode depends on the setting of SYSCR2<DRVE>. SDCKE doesn't depend on it but outputs low level.

If SDRCR<SFRC> is set to 1, the self-refresh cycle shown in Figure 3.16.9 will occur.

The self refreshment mode is used when using the standby mode (STOP, IDLE1) which an internal clock stops. Before HALT instruction (STOP, IDLE1) of interval refreshment in the state of enable, please set SDRCR<SFRC> to 1.

Release of a self refresh cycle is automatically performed by release in the standby mode.

It inserts automatically one interval refreshment after self refreshment release, and returns to the interval refreshment mode.

(Note: When HALT instruction is cancelled by a reset, the I/O registers are initialized, therefore, refresh is not performed.).

Please do not place the command which accesses SDRAM just before the command which sets 1 to SDRCR<SFRC>. After setting SDRCR<SFRC> to 1, make sure that the HALT instruction comes after NOP or some instruction.

#### (3) SDRAM Initialize

After reset release, TMP91C820A can generate the cycle of the following required at the time of the power-supply injection to SDRAM. The cycle is shown in Figure 3.16.10.

- 1. Precharge of all banks
- 2. The initial configuration to a mode registers
- 3. The refresh cycle of 8 cycles

The above mentioned cycle is generated by setting 1 to SDACR<SDINI>.

While this cycle is executing, the CPU operation (instruction fetch, execution) is halted. Before executing the initialization sequence, appropriate port settings must be made to enable the SDRAM control signals and address signals (A1 to A12).



Figure 3.16.10 Initialize Cycle

## (4) Connection example

The example of connection with SDRAM is shown in Figure 3.16.11.



(1 M word  $\times$  4 BANKS  $\times$  16 bits)

Figure 3.16.11 Connection with SDRAM

### (5) Limitation point to use SDRAM

There are some points to notice when using SDRAMC. Please refer to the section under below and take care.

#### 1) WAIT access

When using SDRAM, it is added some limitation of access to all other memories.

Under the N-WAIT setting of this MCU, it is prohibited inserting the time over (14  $\times$  refresh interval time; in Auto Refresh function controlled by SDRAM controller).

2) Execution of SDRAM command before HALT instruction (SR(Self refresh)-Entry, Initialize, Mode-set)

It requires execution time (a few states) to execute the command that SDRAMC has (SR- Entry, Initialize).

Therefore when executing HALT instruction after the SDRAM command, please insert over 10 bytes NOP or other 10 bytes instructions before HALT instruction.

#### 3) AR (Auto Refresh) interval time

When using SDRAM, CPU clock must be set suitable speed for SDRAM's specification that is minimum operating clock and minimum Refresh interval time.

When using SDRAM under slow mode or down the Clock Gear, please design the system with special care for Auto Refresh interval time.

And please set Auto Refresh interval time after adding 10 states to distributed Auto Refresh interval time, because it might not meet the A.C specification of SDRAM by stopping Auto Refresh.

### (Example of calculation)

#### Condition:

fsys = 18MHz, SDRAM specification of distributed Auto Refresh interval time = 4096 times/64 ms

64ms/ 4096 times =  $15.625\mu$ s/1 time = 281.25state/1 time 281.25 - 10 = 271.25 state/less than 1 time is needed  $\rightarrow 247$  state is needed

## 4) Auto Exit problem when exiting from Self Refresh Mode of SDRAM

When using Self Refresh function together with stand-by function of CPU or changing clock, it might not be suit specification of SDRAM. Because automatic releasing Self Refresh function (Auto Exit function) operates by CPU releasing HALT mode.

Following figure shows example for avoid this problem by S/W.

## (Outline concept to control)



<sup>\*</sup>The target ports to change are SDCKE pin and SDCS pin.

<sup>\*</sup>The method of Self refresh Entry includes the condition 4).

<sup>\*</sup> SR : Self refresh , AR : Auto refresh

## 3.17 16-Bit Timer (TMRB)

The TMP91C820A incorporates one multifunctional 16-bit timer (TMRB0) which have the following operation modes:

#### • Interval timer mode

Timer consists of a 16-bit up counter, two 16-bit timer registers (One of them with a double-buffer structure), a 16-bit capture registers, two comparators, a capture input controller, a timer flip-flop and a control circuit.

Timer is controlled by an 11-byte control SFR.

This chapter consists of the following items:

- 3.17.1 Block Diagram
- 3.17.2 Operation
- 3.17.3 SFRs
- 3.17.4 Operation in Each Mode
  - (1) 16-bit timer mode
  - (2) 16-bit programmable pulse generation (PPG) output mode

Channel TMRB0 Spec External clock/capture trigger None input pins External pins Timer flip-flop output pins TB0OUT0 (also used as PB6) Timer run register TB0RUN (0180H) Timer mode register TB0MOD (0182H) Timer flip-flop control register TB0FFCR (0183H) TB0RG0L (0188H) TB0RG0H (0189H) Timer register SFR TB0RG1L (018AH) (Address) TB0RG1H (018BH) TB0CP0L (018CH) TB0CP0H (018DH) Capture register TB0CP1L (018EH) TB0CP1H (018FH)

Table 3.17.1 Pins and SFR of TMRB0

## 3.17.1 Block Diagram



Figure 3.17.1 Block Diagram of TMRB0

## 3.17.2 Operation

#### (1) Prescaler

The 5-bit prescaler generates the source clock for TMRB0. The prescaler clock ( $\phi$ T0) is divided clock (Divided by 4) from selected clock by the register SYSCR0<PRCK1:0> of clock gear. This prescaler can be started or stopped using TB0RUN<TB0RUN>. Counting starts when <TB0RUN> is set to 1; the prescaler is cleared to zero and stops operation when <TB0RUN> is set to 0.

Table 3.17.2 Prescaler Clock Resolution

at fc = 36 MHz, fs = 32.768 kHz

| System                                | Prescaler Clock                  | Clock Gear                   | Prescaler Clock Resolution  |                              |                               |  |  |
|---------------------------------------|----------------------------------|------------------------------|-----------------------------|------------------------------|-------------------------------|--|--|
| Clock<br>Selection<br><sysck></sysck> | Selection<br><prck1:0></prck1:0> | Value<br><gear2:0></gear2:0> | фТ1                         | фТ4                          | φТ16                          |  |  |
| 1 (fs)                                |                                  | XXX                          | 2 <sup>3</sup> /fs (244 μs) | 2 <sup>5</sup> /fs (977 μs)  | 2 <sup>7</sup> /fs (3.9 ms)   |  |  |
|                                       |                                  | 000 (fc)                     | 2 <sup>3</sup> /fc (0.2 μs) | 2 <sup>5</sup> /fc (0.9 μs)  | 2 <sup>7</sup> /fc (3.6 μs)   |  |  |
|                                       | 00                               | 001 (fc/2)                   | 2 <sup>4</sup> /fc (0.4 μs) | 2 <sup>6</sup> /fc (1.8 μs)  | 2 <sup>8</sup> /fc (7.1 μs)   |  |  |
|                                       | (f <sub>FPH</sub> )              | 010 (fc/4)                   | 2 <sup>5</sup> /fc (0.9 μs) | 2 <sup>7</sup> /fc (3.6 μs)  | 2 <sup>9</sup> /fc (14.2 μs)  |  |  |
| 0 (fc)                                |                                  | 011 (fc/8)                   | 2 <sup>6</sup> /fc (1.8 μs) | 2 <sup>8</sup> /fc (7.1 μs)  | 2 <sup>10</sup> /fc (28.4 μs) |  |  |
|                                       |                                  | 100 (fc/16)                  | 2 <sup>7</sup> /fc (3.6 μs) | 2 <sup>9</sup> /fc (14.2 μs) | 2 <sup>11</sup> /fc (56.9 μs) |  |  |
|                                       | 10<br>(fc/16 clock)              | XXX                          | 2 <sup>7</sup> /fc (3.6μs)  | 2 <sup>9</sup> /fc (14.2 μs) | 2 <sup>11</sup> /fc (56.9 μs) |  |  |

xxx: Don't care

### (2) Up counter (UC0)

UC0 is a 16-bit binary counter which counts up pulses input from the clock specified by TB0MOD<TB0CLK1:0>.

Any one of the prescaler internal clocks  $\phi T1$ ,  $\phi TB0$  and  $\phi T16$  can be selected as the input clock. Counting or stopping and clearing of the counter is controlled by TB0RUN<TB0RUN>.

When clearing is enabled, the up counter UC0 will be cleared to zero each time its value matches the value in the timer register TB0RG1H/L. Clearing can be enabled or disabled using TB0MOD<TB0CLE>.

If clearing is disabled, the counter operates as a free running counter.

A timer overflow interrupt (INTTBOF0) is generated when UC0 overflow occurs.

#### (3) Timer registers (TB0RG0 and TB0RG1)

These two 16-bit registers are used to set the interval time. When the value in the up counter UC0 matches the value set in this timer register, the comparator match detect signal will go active.

Setting data for both upper and lower timer registers is needed. For example, using 2-byte data transfer instruction or using 1-byte date transfer instruction twice for lower 8 bits and upper 8 bits in order.

The TB0RG0 timer register has a double-buffer structure, which is paired with register buffer. The value set in TB0RUN<TB0RDE> determines whether the double-buffer structure is enabled or disabled: it is disabled when <TB0RDE> = 0, and enabled when <TB0RDE> = 1.

When the double buffer is enabled, data is transferred from the register buffer to the timer register when the values in the up counter (UC0) and the timer register TB0RG1 match.

After a reset, TB0RG0 and TB0RG1 are undefined. If the 16-bit timer is to be used after a reset, data should be written to it beforehand.

On a reset <TB0RDE> is initialized to 0, disabling the double buffer. To use the double buffer, write data to the timer register, set <TB0RDE> to 1, then write data to the register buffer as shown below.

TB0RG0 and the register buffer both have the same memory addresses (000188H and 000189H) allocated to them. If <TB0RDE> = 0, the value is written to both the timer register and the register buffer. If <TB0RDE> = 1, the value is written to the register buffer only.

The addresses of the timer registers are as follows:



The timer registers are write-only registers and thus cannot be read.

### (4) Capture registers (TB0CP0H/L)

These 16-bit registers are used to latch the values in the up counters.

Data in the capture registers should be read all 16 bits. For example, using a 2-byte data load instruction or two 1-byte data load instructions. The least significant byte is read first, followed by the most significant byte.

The addresses of the capture registers are as follows:



The capture registers are read-only registers and thus cannot be written to.

### (5) Capture input control

This circuit controls the timing to latch the value of up-counter UC0 into TB0CP0.

The value in the up-counter can be loaded into a capture register by software. Whenever 0 is written to TB0MOD<TB0CP0I>, the current value in the up counter is loaded into capture register TB0CP0. It is necessary to keep the prescaler in RUN mode (e.g., TB0RUN<TB0PRUN> must be held at a value of 1).

#### (6) Comparators (CP0 and CP1)

CP0 and CP1 are 16-bit comparators which compare the value in the up counter UC0 with the value set in TB0RG0 or TB0RG1 respectively, in order to detect a match. If a match is detected, the comparator generates an interrupt (INTTB00 or INTTB01 respectively).

Note: As described above, whenever 0 is written to TB0MOD<TB0CP0I>, the current value in the up counter is loaded into capture register TB0CP0. However, note that the current value in the up counter is also loaded into capture register TB0CP0 when 1 is written to TB0MOD<TB0CP0I> while this bit is holding 0.



#### (7) Timer flip-flops (TB0FF0)

These flip-flops are inverted by the match detect signals from the comparators and the latch signals to the capture registers. Inversion can be enabled and disabled for each element using TB0FFCR<TB0C0T1, TB0E1T1, TB0E0T1>.

After a reset the value of TB0FF0 is undefined. If 00 is written to TB0FFCR <TB0FF0C1:0> or <TB0FF1C1:0>, TB0FF0 will be inverted. If 01 is written to the capture registers, the value of TB0FF0 will be set to 1. If 10 is written to the capture registers, the value of TB0FF0 will be set to 0.

The values of TB0FF0 can be output via the timer output pins TB0OUT0 (which is shared with PB6). Timer output should be specified using the port B function register.

## 3.17.3 SFRs

## TMRB0 Run Register

TB0RUN (0180H)

| I |             | 7          | 6        | 5 | 4 | 3          | 2                 | 1           | 0              |  |
|---|-------------|------------|----------|---|---|------------|-------------------|-------------|----------------|--|
|   | Bit symbol  | TB0RDE     | =        |   |   | I2TB0      | TB0PRUN           |             | TB0RUN         |  |
| ı | Read/Write  | R/W        | R/W      |   |   | R/W        | R/W               |             | R/W            |  |
|   | After reset | 0          | 0        |   |   | 0          | 0                 |             | 0              |  |
|   | Function    | Double     | Always   |   |   | IDLE2      | 16-Bit timer      | run/stop co | ntrol          |  |
|   |             | buffer     | fixed to |   |   | 0: Stop    | 0: Stop and clear |             |                |  |
|   |             | 0: Disable | "0".     |   |   | 1: Operate | 1: Run (Cou       | ınt up)     |                |  |
| ı |             | 1: Enable  |          |   |   |            |                   |             |                |  |
|   |             |            |          |   |   |            |                   |             |                |  |
|   |             |            |          |   |   |            |                   | → Count op  | eration        |  |
|   |             |            |          |   |   |            |                   | 0 9         | Stop and clear |  |

0 Stop and clear 1 Count

I2TB0: Operation during IDLE2 mode TB0PRUN: Operation of prescaler TB0RUN: Operation of TMRB0

Note: The 1, 4 and 5 of TB0RUN are read as undefined value.

Figure 3.17.2 Register for TMRB

## TMRB0 Mode Register

| -                                  |                   |             |     |                                                 |           |          |                                                           |                                                                 |              |
|------------------------------------|-------------------|-------------|-----|-------------------------------------------------|-----------|----------|-----------------------------------------------------------|-----------------------------------------------------------------|--------------|
|                                    |                   | 7           | 6   | 5                                               | 4         | 3        | 2                                                         | 1                                                               | 0            |
| TB0MOD                             | Bit symbol        | -           | -   | TB0CP01                                         | -         | =        | TB0CLE                                                    | TB0CLK1                                                         | TB0CLK0      |
| (0182H)                            | Read/Write        | R           | W   | W*                                              | R/W       | R/W      |                                                           | R/W                                                             |              |
| Prohibit                           | After reset       | 0           | 0   | 1                                               | 0         | 0        | 0                                                         | 0                                                               | 0            |
| Prohibit read-<br>modify-<br>write | Function Function | Always writ |     | Execute software capture 0: Execute 1: Undefine | Always wi |          | Control up counter 0: Disable clearing 1: Enable clearing | 0<br>TMRB0 sou<br>00: Reserve<br>01: φT1<br>10: φT4<br>11: φT16 | ırce clock   |
|                                    |                   |             |     |                                                 |           |          |                                                           |                                                                 | TD0DC4       |
|                                    |                   |             |     |                                                 |           | •        | 31 clearing or                                            | match with                                                      | IBORG1.      |
|                                    |                   |             | Sof | tware capture                                   |           |          | (                                                         |                                                                 |              |
|                                    |                   |             |     |                                                 | _         |          | lue in the up                                             | counter is ca                                                   | ptured to TB |
|                                    |                   |             |     |                                                 | <u> </u>  | 1 Undefi | ned (Note)                                                |                                                                 |              |

Note: As described above, whenever 0 is written to TB0MOD<TB0CP0I>, the current value in the up counter is loaded into capture register TB0CP0. However, note that the current value in the up counter is also loaded into capture register TB0CP0 when 1 is written to TB0MOD<TB0CP0I> while this bit is holding 0.

Figure 3.17.3 Register for TMRB



Figure 3.17.4 Register for TMRB

|         |             |           |           | Tiı | mer register |       |   |   |   |  |  |  |  |
|---------|-------------|-----------|-----------|-----|--------------|-------|---|---|---|--|--|--|--|
|         |             | 7         | 6         | 5   | 4            | 3     | 2 | 1 | 0 |  |  |  |  |
| TB0RG0L | bit Symbol  |           | -         |     |              |       |   |   |   |  |  |  |  |
| (0188H) | Read/Write  |           | W         |     |              |       |   |   |   |  |  |  |  |
|         | After reset |           |           |     | Unde         | fined |   |   |   |  |  |  |  |
| TB0RG0H | bit Symbol  |           | -         |     |              |       |   |   |   |  |  |  |  |
| (0189H) | Read/Write  |           | W         |     |              |       |   |   |   |  |  |  |  |
|         | After reset | Undefined |           |     |              |       |   |   |   |  |  |  |  |
| TB0RG1L | bit Symbol  |           | -         |     |              |       |   |   |   |  |  |  |  |
| (018AH) | Read/Write  | W         |           |     |              |       |   |   |   |  |  |  |  |
|         | After reset |           | Undefined |     |              |       |   |   |   |  |  |  |  |
| TB0RG1H | bit Symbol  |           | -         |     |              |       |   |   |   |  |  |  |  |
| (018BH) | Read/Write  |           |           |     | V            | V     |   |   |   |  |  |  |  |
|         | After reset |           |           |     | Unde         | fined |   |   |   |  |  |  |  |

Note: Above registers are prohibited Read-modify-write instruction. \\

Figure 3.17.5 Register for TMRB

## 3.17.4 Operation in Each Mode

#### (1) 16-bit timer mode

Generating interrupts at fixed intervals

In this example, the interrupt INTTB01 is set to be generated at fixed intervals. The interval time is set in the timer register TB0RG1.

| _        |              | 7 | 6 | 5 | 4 | 3     | 2   | 1   | 0   |                                                            |
|----------|--------------|---|---|---|---|-------|-----|-----|-----|------------------------------------------------------------|
| TB0RUN   | $\leftarrow$ | 0 | 0 | Χ | Χ | -     | 0   | Χ   | 0   | Stop TMRB0.                                                |
| INTETB01 | $\leftarrow$ | Χ | 1 | 0 | 0 | Χ     | 0   | 0   | 0   | Enable INTTB01 and set interrupt level 4. Disable INTTB00. |
| TB0FFCR  | $\leftarrow$ | 1 | 1 | 0 | 0 | 0     | 0   | 1   | 1   | Disable the trigger.                                       |
| TB0MOD   | $\leftarrow$ | 0 | 0 | 1 | 0 | 0     | 1   | *   | *   | Select internal clock for input and                        |
|          |              |   |   |   |   | (** = | 01, | 10, | 11) | disable the capture function.                              |
| TB0RG1   | $\leftarrow$ | * | * | * | * | *     | *   | *   | *   | Set the interval time.                                     |
|          |              | * | * | * | * | *     | *   | *   | *   | (16 bits)                                                  |
| TB0RUN   | $\leftarrow$ | 0 | 0 | Χ | Χ | -     | 1   | Χ   | 1   | Start TMRB0.                                               |
|          |              |   |   |   |   |       |     |     |     |                                                            |

X: Don't care, -: No change

## (2) 16-bit programmable pulse generation (PPG) output mode

Square wave pulses can be generated at any frequency and duty ratio. The output pulse may be either low active or high active.

The PPG mode is obtained by inversion of the timer flip-flop TB0FF0 that is to be enabled by the match of the up counter UC0 with timer register TB0RG0 or TB0RG1 and to be output to TB0OUT0. In this mode the following conditions must be satisfied.

(Value set in TB0RG0) < (Value set in TB0RG1)



Figure 3.17.6 Programmable Pulse Generation (PPG) Output Waveforms

When the TB0RG0 double buffer is enabled in this mode, the value of register buffer 0 will be shifted into TB0RG0 at match with TB0RG1. This feature facilitates the handling of low-duty waves.



Figure 3.17.7 Operation of Register Buffer

The following block diagram illustrates this mode.



Figure 3.17.8 Block Diagram of 16-Bit Mode

The following example shows how to set 16-bit PPG output mode:

```
TB0RUN
                                                         Disable the TB0RG0 double buffer and stop TMRB0.
TB0RG0
                                                         Set the duty ratio.
                                                         (16 bits)
TB0RG1
                                                         Set the frequency.
                                                         (16 bits)
TB0RUN
                                                         Enable the TB0RG0 double buffer.
                                                         (The duty and frequency are changed on an INTTB01
                                                         interrupt.)
TB0FFCR
                                                         Set the mode to invert TB0FF0 at the match with
              \leftarrow X \quad X \quad 0
                              0
                                                         TB0RG0/TB0RG1. Set TB0FF0 to 0.
TB0MOD
                                  0
                                                         Select the internal clock as the input clock and disable
                                  ** = 01, 10, 11)
                                                         the capture function.
PBCR
                                                         Set PB6 to function as TB0OUT0.
PBFC
TB0RUN
                                                         Start TMRB0.
```

X: Don't care, -: No change

## 3.18 Hardware Standby Function

TMP91C820A have hardware standby circuit that is able to save the power consumption and protect from program runaway by supplying power voltage down. Especially, it's useful in case of battery using.

It can be shifted to "PS condition" by fixed  $\overline{PS}$  pin to "low" level.

Figure 3.18.1 shows timing diagram of transition of PS condition below.

PS mode can release only external system reset.



Note 1:  $\overline{PS}$  pin is effective after RESET because SYSCR2<PSENV> to 0. If you use as  $\overline{NMI}$  pin, please write SYSCR2<PSENV> to 1.

Note 2: Shifting time is 2 to 10 clock times of f<sub>SYS</sub>.

Figure 3.18.1 Hardware Standby Timing Diagram

Table 3.18.1 Power Save Mode Conditions of Each HALT Mode

| HALT Mode Setting | IDLE2                 | IDLE1                 | STOP        |
|-------------------|-----------------------|-----------------------|-------------|
| PS condition      | IDLE1 mode            | IDLE1 mode            | STOP mode   |
| F3 condition      | + High-frequency stop | + High-frequency stop | STOP IIIode |

Note: Settings of SYSCR2<DRVE> and <SELDRV> at HALT mode are effective as well as PS condition.

## 4. Electrical Characteristics

## 4.1 Maximum Ratings

| Parameter                     | Symbol  | Rating            | Unit |
|-------------------------------|---------|-------------------|------|
| Power supply voltage          | Vcc     | -0.5 to 4.0       | V    |
| Input voltage                 | VIN     | -0.5 to Vcc + 0.5 | V    |
| Output current                | IOL     | 2                 |      |
| Output current                | IOH     | -2                | mA   |
| Output current (Total)        | ΣΙΟL    | 80                | IIIA |
| Output current (Total)        | ΣΙΟΗ    | -80               |      |
| Power dissipation (Ta = 85°C) | PD      | 600               | mW   |
| Soldering temperature (10 s)  | TSOLDER | 260               |      |
| Storage temperature           | TSTG    | -65 to 150        | °C   |
| Operating temperature         | TOPR    | -20 to 70         |      |

Note: The maximum ratings are rated values which must not be exceeded during operation, even for an instant. Any one of the ratings must not be exceeded. If any maximum rating is exceeded, a device may break down or its performance may be degraded, causing it to catch fire or explode resulting in injury to the user. Thus, when designing products which include this device, ensure that no maximum rating value will ever be exceeded.

## 4.2 DC Characteristics (1/2)

|                    | Parameter Symbol                 |      | Cond                                      | dition            | Min       | Тур. | Max       | Unit |
|--------------------|----------------------------------|------|-------------------------------------------|-------------------|-----------|------|-----------|------|
|                    | wer supply voltage               | vcc  | fc = 4 to 27 MHz                          | fs = 30 to 34 kHz | 2.7       | -    | 3.6       | V    |
| ١,                 | /CC = DVCC)<br>/SS = DVSS = 0 V) | VCC  | fc = 4 to 36 MHz                          | 18 = 30 to 34 km2 | 3.0       | -    | 3.6       | V    |
|                    | D0 to D15                        | VIL  | $V_{CC} \ge 2.7 \text{ V}$                |                   |           | -    | 0.6       |      |
| /oltage            | P52 to P7<br>(except PB3, P9)    | VIL1 | V <sub>CC</sub> ≥ 2.7 V                   |                   |           | -    | 0.3 Vcc   |      |
| Input low voltage  | RESET, NMI,<br>PB3 (INT0), P9    | VIL2 | V <sub>CC</sub> ≥ 2.7 V                   |                   | -0.3      | -    | 0.25 Vcc  |      |
| du                 | AM0 to AM1                       | VIL3 | $V_{CC} \ge 2.7 \text{ V}$                |                   |           | -    | 0.3       |      |
|                    | X1                               | VIL4 | $V_{CC} \ge 2.7 \text{ V}$                |                   |           | -    | 0.2 Vcc   | V    |
|                    | D0 to D15                        | VIH  | $3.6 \text{ V} \ge \text{V}_{CC} \ge 2.7$ | ' V               | 2.0       | -    |           | V    |
| Input high voltage | P52 to P7<br>(except PB3, P9)    | VIH1 | $V_{CC} \ge 2.7 \text{ V}$                |                   | 0.7 Vcc   | -    |           |      |
| t high t           | RESET, NMI,<br>PB3 (INT0), P9    | VIH2 | $V_{CC} \ge 2.7 \text{ V}$                |                   | 0.75 Vcc  | -    | Vcc + 0.3 |      |
| Inpu               | AM0 to AM1                       | VIH3 | $V_{CC} \ge 2.7 \text{ V}$                |                   | Vcc - 0.3 | -    |           |      |
|                    | X1                               | VIH4 | V <sub>CC</sub> ≥ 2.7 V                   |                   | 0.8 Vcc   | -    |           |      |
| Ou                 | tput low voltage                 | VOL  | IOL = 1.6 mA                              |                   |           | -    | 0.45      | V    |
| Ou                 | tput high voltage                | VOH  | $IOH = -400 \mu A$                        |                   | 2.4       | -    | -         | V    |

Note: Typical values are for when Ta = 25°C and Vcc = 3.0 V unless otherwise noted.

# DC Characteristics (2/2)

| Parameter                                  | Symbol | Condition                                           | Min | Typ.<br>(Note 1) | Max  | Unit |
|--------------------------------------------|--------|-----------------------------------------------------|-----|------------------|------|------|
| Input leakage current                      | ILI    | 0.0 ≤ VIN≤ Vcc                                      | -   | 0.02             | ±5   | μА   |
| Output leakage current                     | ILO    | 0.2≤ VIN≤ Vcc - 0.2                                 | -   | 0.05             | ±10  | μА   |
| Power down voltage (at STOP, RAM back up)  | VSTOP  | VIL2 = 0.2Vcc,<br>VIH2 = 0.8Vcc                     | 1.8 | -                | 3.6  | V    |
| RESET pull-up resistor                     | RRST   | $3.6 \text{ V} \ge \text{V}_{CC} \ge 2.7 \text{ V}$ | 100 | _                | 400  | kΩ   |
| Pin capacitance                            | CIO    | fc = 1 MHz                                          | -   | -                | 10   | pF   |
| Schmitt width RESET, NMI, INTO, KIO to KI7 | VTH    | V <sub>CC</sub> ≥ 2.7 V                             | 0.4 | 1.0              | -    | ٧    |
| Programmable pull-up resistor              | RKH    | $3.6~\text{V} \geq \text{V}_{CC} \geq 2.7~\text{V}$ | 100 | -                | 400  | kΩ   |
| NORMAL (Note 2)                            |        |                                                     | -   | 23.0             | 35.0 |      |
| IDLE2                                      |        | Vcc = 3.6 V<br>fc = 36M Hz                          | -   | 16.0             | 23.0 | mA   |
| IDLE1                                      |        | 10 - 30101112                                       | -   | 1.6              | 3.0  |      |
| SLOW (Note 2)                              | Icc    | V 0.0 V                                             |     | 23.0             | 45.0 |      |
| IDLE2                                      |        | Vcc = 3.6 V<br>fs = 32.768 kHz                      | _   | 14.0             | 35.0 | μΑ   |
| IDLE1                                      |        | 10 - 02.7 00 KHZ                                    | _   | 6.0              | 25.0 |      |
| STOP                                       |        | Vcc = 3.6 V                                         | -   | 0.2              | 15.0 | μΑ   |

Note 1: Typical values are for when  $Ta = 25^{\circ}C$  and Vcc = 3.0 V unless otherwise noted.

Note 2: Icc measurement conditions (NORMAL, SLOW):

All functions are operational; output pins are open and input pins are fixed. CL = 30 pF loaded on data and address bus.

## 4.3 AC Characteristics

 $\label{eq:Vcc} \begin{aligned} &\text{Vcc} = 2.7 \text{ to } 3.6 \text{ V case of } f_{\text{FPH}} = 27 \text{ MHz} \\ &\text{Vcc} = 3.0 \text{ to } 3.6 \text{ V case of } f_{\text{FPH}} = 36 \text{ MHz} \end{aligned}$ 

| No. | Symbol            | Parameter                                                                                | Varia     | able      |       | = 27<br>Hz |       | = 36<br>Hz | Unit |
|-----|-------------------|------------------------------------------------------------------------------------------|-----------|-----------|-------|------------|-------|------------|------|
|     |                   |                                                                                          | Min       | Max       | Min   | Max        | Min   | Max        |      |
| 1   | t <sub>FPH</sub>  | f <sub>FPH</sub> period (= x)                                                            | 27.7      | 31250     | 37    |            | 27.7  |            | ns   |
| 2   | t <sub>AC</sub>   | A0 to A23 valid $\rightarrow \overline{RD} / \overline{WR} \text{ fall}$                 | x – 23    |           | 14    |            | 4.7   |            | ns   |
| 3   | tCAR              | $\overline{\text{RD}}$ rise $\rightarrow$ A0 to A23 hold                                 | 0.5x -13  |           | 5.5   |            | 0.85  |            | ns   |
| 4   | t <sub>CAW</sub>  | $\overline{\text{WR}}$ rise $\rightarrow$ A0 to A23 hold                                 | x – 13    |           | 24    |            | 14.7  |            | ns   |
| 5   | t <sub>AD</sub>   | A0 to A23 valid $\rightarrow$ D0 to D15 input                                            |           | 3.5x - 24 |       | 105.5      |       | 72.95      | ns   |
| 6   | t <sub>RD</sub>   | $\overline{RD}$ fall $\rightarrow$ D0 to D15 input                                       |           | 2.5x - 24 |       | 68.5       |       | 45.25      | ns   |
| 7   | t <sub>RR</sub>   | RD low width                                                                             | 2.5x - 15 |           | 77.5  |            | 54.25 |            | ns   |
| 8   | t <sub>HR</sub>   | $\overline{RD}$ rise $\rightarrow$ D0 to D15 hold                                        | 0         |           | 0     |            | 0     |            | ns   |
| 9   | t <sub>WW</sub>   | WR low width                                                                             | 2x - 15   |           | 59    |            | 40.4  |            | ns   |
| 10  | t <sub>DW</sub>   | D0 to D15 valid $\rightarrow \overline{WR}$ rise                                         | 1.5x - 35 |           | 20.5  |            | 5.5   |            | ns   |
| 11  | t <sub>WD</sub>   | $\overline{\text{WR}}$ rise $\rightarrow$ D0 to D15 hold                                 | x – 25    |           | 12    |            | 2.7   |            | ns   |
| 12  | t <sub>SBA</sub>  | Data byte control access time for SRAM                                                   |           | 3x - 39   |       | 72         |       | 44.1       | ns   |
| 13  | t <sub>SWP</sub>  | Write pulse width for SRAM                                                               | 2x - 15   |           | 59    |            | 40.4  |            | ns   |
| 14  | t <sub>SBW</sub>  | Data byte control to end of write for SRAM                                               | 3x - 25   |           | 86    |            | 58.1  |            | ns   |
| 15  | t <sub>SAS</sub>  | Address setup time for SRAM                                                              | 1.5x - 35 |           | 20.5  |            | 6.55  |            | ns   |
| 16  | tswr              | Write recovery time for SRAM                                                             | 0.5x - 13 |           | 5.5   |            | 0.85  |            | ns   |
| 17  | t <sub>SDS</sub>  | Data setup time for SRAM                                                                 | 2x - 35   |           | 39    |            | 20.4  |            | ns   |
| 18  | tSDH              | Data hold time for SRAM                                                                  | 0.5x - 13 |           | 5.5   |            | 0.85  |            | ns   |
| 19  | t <sub>AW</sub>   | A0 to A23 valid $\rightarrow \overline{WAIT}$ input (1 + N) wait                         |           | 3.5x - 60 |       | 69.5       |       | 36.95      | ns   |
| 20  | t <sub>CW</sub>   | $\overline{RD}$ / $\overline{WR}$ fall $\rightarrow$ $\overline{WAIT}$ hold (1 + N) wait | 2.5x + 0  |           | 92.5  |            | 69.25 |            | ns   |
| 21  | t <sub>APH</sub>  | A0 to A23 valid → PORT input                                                             |           | 3.5x - 89 |       | 40.5       |       | 7.95       | ns   |
| 22  | t <sub>APH2</sub> | A0 to A23 valid → PORT hold                                                              | 3.5x      |           | 129.5 |            | 96.95 |            | ns   |
| 23  | t <sub>APO</sub>  | A0 to A23 valid $\rightarrow$ PORT valid                                                 |           | 3.5x + 60 |       | 189.5      |       | 156.9      | ns   |

## AC measuring conditions

• Output Level: High = 0.7 Vcc, Low = 0.3 Vcc, CL = 50 pF

• Input Level: High = 0.9 Vcc, Low = 0.1 Vcc

Note: Symbol x in the above table means the period of clock f<sub>FPH</sub>, it's half period of the system clock f<sub>SYS</sub> for CPU core. The period of f<sub>FPH</sub> depends on the clock gear setting or the selection of high-/low-frequency oscillator.

## (1) Read cycle



Note: Since the CPU accesses the internal area to read data from a port, the control signals of external pins such as  $\overline{\text{RD}}$  and  $\overline{\text{CS}}$  are not enabled. Therefore, the above waveform diagram should be regarded as depicting internal operation. Please also note that the timing and AC characteristics of port input/output shown above are typical representation. For details, contact your local Toshiba sales representative.

## (2) Write cycle



Note: Since the CPU accesses the internal area to write data to a port, the control signals of external pins such as  $\overline{\text{WR}}$  and  $\overline{\text{CS}}$  are not enabled. Therefore, the above waveform diagram should be regarded as depicting internal operation. Please also note that the timing and AC characteristics of port input/output shown above are typical representation. For details, contact your local Toshiba sales representative.

## 4.4 SDRAM Controller AC Electrical Characteristics

 $\label{eq:Vcc} \begin{aligned} &\text{Vcc} = 2.7 \text{ to } 3.6 \text{ V case of } f_{\text{FPH}} = 27 \text{ MHz} \\ &\text{Vcc} = 3.0 \text{ to } 3.6 \text{ V case of } f_{\text{FPH}} = 36 \text{ MHz} \end{aligned}$ 

| Na  | Cumbal           | Dorometer                               | Varia   | able  | 27 [ | ИНz   | 36 N  | MHz   | Unit  |
|-----|------------------|-----------------------------------------|---------|-------|------|-------|-------|-------|-------|
| No. | Symbol           | Parameter                               | Min     | Max   | Min  | Max   | Min   | Max   | Uniit |
| 1   | t <sub>RC</sub>  | Ref/active to ref/active command period | 4X      |       | 148  |       | 27.7  |       | ns    |
| 2   | t <sub>RAS</sub> | Active to precharge command period      | 4X      | 12210 | 148  | 12210 | 111.1 | 12210 | ns    |
| 3   | t <sub>RCD</sub> | Active to read/write command delay time | 2X      |       | 74   |       | 55.6  |       | ns    |
| 4   | t <sub>RP</sub>  | Precharge to active command period      | 2X      |       | 74   |       | 55.6  |       | ns    |
| 5   | t <sub>RRD</sub> | Active to active command period         | 6X      |       | 222  |       | 166.7 |       | ns    |
| 6   | t <sub>WR</sub>  | Write recovery time (CL* = 2)           | 2X      |       | 74   |       | 55.6  |       | ns    |
| 7   | t <sub>WR2</sub> | Write recovery time                     | 3X      |       | 111  |       | 83    |       |       |
| 8   | tCK              | CLK cycle time (CL* = 2)                | 2X      |       | 74   |       | 55.6  |       | ns    |
| 9   | tCH              | CLK high level width                    | 1X-15   |       | 22   |       | 12.8  |       | ns    |
| 10  | t <sub>CL</sub>  | CLK low level width                     | 1X-15   |       | 22   |       | 12.8  |       | ns    |
| 11  | t <sub>AC</sub>  | Access time from CLK (CL* = 2)          |         | 1X-25 |      | 12    |       | 2.8   | ns    |
| 12  | tOH              | Output data hold time                   | 0       |       | 0    |       | 0     |       | ns    |
| 13  | t <sub>DS</sub>  | Data-in setup time                      | 2X-35   |       | 39   |       | 20.6  |       | ns    |
| 14  | t <sub>DH</sub>  | Data-in hold time                       | 2.5X-20 |       | 72   |       | 49.4  |       | ns    |
| 15  | t <sub>AS</sub>  | Address setup time                      | 1.5X-35 |       | 20   |       | 6.7   |       | ns    |
| 16  | t <sub>AH</sub>  | Address hold time                       | 0.5X-13 |       | 5    |       | 0.9   |       | ns    |
| 17  | tcks             | CKE setup time                          | 1X-15   |       | 22   |       | 12.8  |       | ns    |
| 18  | t <sub>CMS</sub> | Command setup time                      | 1X-15   |       | 22   |       | 12.8  |       | ns    |
| 19  | tCMH             | Command hold time                       | 1X-15   |       | 22   |       | 12.8  |       | ns    |
| 20  | t <sub>RSC</sub> | Mode register set cycle time            | 2X      |       | 74   |       | 55.6  |       | ns    |

 $<sup>\</sup>ast$  CL is  $\overline{\text{CAS}}$  latency.

AC measuring conditions

• Output level: High = 0.7 Vcc, Low = 0.3 Vcc, CL = 50 pF

• Input level: High = 0.9 Vcc, Low = 0.1 Vcc

Note: Symbol x in the above table means the period of clock f<sub>FPH</sub>, it's half period of the system clock f<sub>SYS</sub> for CPU core. The period of f<sub>FPH</sub> depends on the clock gear setting or the selection of high-/low-frequency oscillator.

• SDRAM read timing (CPU access)



• SDRAM write timing (CPU access)



• SDRAM write timing (CPU access, write recivery enable)



• SDRAM burst read timing (Head of burst cycle)



• SDRAM burst read timing (End of burst cycle)



## • SDRAM initialize timing



## • SDRAM refresh timing



## • SDRAM self-refresh timing



## 4.5 AD Conversion Characteristics

AVcc = Vcc, AVss = Vss

| Symbol                                | Parameter                                                                    | Condition            | Min               | Тур. | Max               | Unit |
|---------------------------------------|------------------------------------------------------------------------------|----------------------|-------------------|------|-------------------|------|
| VREFH                                 | Analog reference voltage (+)                                                 |                      | Vcc – 0.2 V       | Vcc  | Vcc               |      |
| VREFL                                 | Analog reference voltage (-)                                                 |                      | Vss               | Vss  | Vss + 0.2 V       | V    |
| VAIN                                  | Analog input voltage range                                                   |                      | V <sub>REFL</sub> |      | V <sub>REFH</sub> |      |
| IREF<br>(VREFL = 0V)                  | Analog current for analog reference voltage <pre><vrefon> = 1</vrefon></pre> | VCC = 2.7 V to 3.6 V |                   | 0.94 | 1.20              | mA   |
| , , , , , , , , , , , , , , , , , , , | <vrefon> = 0</vrefon>                                                        |                      |                   | 0.02 | 5.0               | μА   |
| -                                     | Error (Not including quantizing errors)                                      |                      |                   | ±1.0 | ±4.0              | LSB  |

Note 1: 1 LSB = (VREFH - VREFL)/1024 [V].

Note 2: The operation above is guaranteed for  $f_{FPH} \ge 4$  MHz.

Note 3: The value of lcc includes the current which flows through the AVCC pin.

# 4.6 Serial Channel Timing (I/O internal mode)

## (1) SCLK input mode

Vcc = 2.7 to 3.6 V case of  $f_{FPH} = 27$  MHz Vcc = 3.0 to 3.6 V case of  $f_{FPH} = 36$  MHz

| Symbol           | Parameter                                     | Variab                       | le                   | 27 N | ЛHz | 36 I | MHz | Unit  |
|------------------|-----------------------------------------------|------------------------------|----------------------|------|-----|------|-----|-------|
| Symbol           | raiaillelei                                   | Min                          | Max                  | Min  | Max | Min  | Max | Offic |
| tscy             | SCLK period                                   | 16X                          |                      | 0.59 |     | 0.44 |     | μS    |
| toss             | Output data  → SCLK rising/falling edge*      | t <sub>SCY</sub> /2 - 4X-110 |                      | 38   |     | 0    |     | ns    |
| tons             | SCLK rising/falling edge*  → Output data hold | t <sub>SCY</sub> /2 + 2X + 0 |                      | 370  |     | 277  |     | ns    |
| t <sub>HSR</sub> | SCLK rising/falling edge*  → Input data hold  | 3X + 10                      |                      | 121  |     | 93   |     | ns    |
| t <sub>SRD</sub> | SCLK rising/falling edge*  → Valid data input |                              | t <sub>SCY</sub> - 0 |      | 592 |      | 443 | ns    |
| t <sub>RDS</sub> | SCLK rising/falling edge*  → Valid data input | 0                            |                      | 0    |     | 0    |     | ns    |

## (2) SCLK output mode

| Symbol           | Parameter                                     | Vai                      | Variable                    |      |     | 36 [  | Unit |       |
|------------------|-----------------------------------------------|--------------------------|-----------------------------|------|-----|-------|------|-------|
| Symbol           | Faiailletei                                   | Min                      | Max                         | Min  | Max | Min   | Max  | Offic |
| tscy             | SCLK period                                   | 16X                      | 8192X                       | 0.59 | 303 | 0.44  | 227  | μS    |
| toss             | Output data  → SCLK rising/falling edge*      | t <sub>SCY</sub> /2 - 40 |                             | 256  |     | 181   |      | ns    |
| tons             | SCLK rising/falling edge*  → Output data hold | t <sub>SCY</sub> /2 - 40 |                             | 256  |     | 181   |      | ns    |
| tHSR             | SCLK rising/falling edge*  → Input data hold  | 0                        |                             | 0    |     | 0     |      | ns    |
| tSRD             | SCLK rising/falling edge∗  → Valid data input |                          | t <sub>SCY</sub> – 1X – 180 |      | 375 |       | 235  | ns    |
| t <sub>RDS</sub> | SCLK rising/falling edge*  → Valid data input | 1X + 180                 |                             | 217  |     | 207.7 |      | ns    |

SCLK rising/falling edge\*:

The rising edge is used in SCLK rising mode.

The Falling edge is used in SCLK falling mode.

Note: Above table's data values at 27 MHz and 36 MHz are calculated from  $t_{SCY} = 16x$  base.



# 4.7 Timer input pulse (TA0IN)

| Symbol            | Parameter              | Varia    | Variable ( |     | Hz<br>to 3.6 V) | 36 N<br>(Vcc = 3.0 | Unit |    |  |
|-------------------|------------------------|----------|------------|-----|-----------------|--------------------|------|----|--|
|                   |                        | Min      | Max        | Min | Max             | Min                | Max  | 01 |  |
| t <sub>VCK</sub>  | Clock period           | 8X + 100 |            | 396 |                 | 321                |      | ns |  |
| t <sub>VCKL</sub> | Clock low level width  | 4X + 40  |            | 188 |                 | 151                |      | ns |  |
| tvckh             | Clock high level width | 4X + 40  |            | 188 |                 | 151                |      | ns |  |

# 4.8 Interrupt, Capture

(1)  $\overline{\text{NMI}}$ , INT0 to INT3 interrupts

| Symbol             | Parameter                                               | Varia   | ble | 27 MI<br>(Vcc = 2.7 t |     | 36 N<br>(Vcc = 3.0 | Unit |    |
|--------------------|---------------------------------------------------------|---------|-----|-----------------------|-----|--------------------|------|----|
|                    |                                                         | Min     | Max | Min                   | Max | Min                | Max  |    |
| t <sub>INTAL</sub> | NMI, INTO to INT3 low level width                       | 4X + 40 |     | 188                   |     | 151                |      | ns |
| t <sub>INTAH</sub> | $\overline{\text{NMI}}$ , INT0 to INT3 high level width | 4X + 40 |     | 188                   |     | 151                |      | ns |

## 4.9 LCD Controller SR Mode



 $\label{eq:Vcc} \begin{aligned} \text{Vcc} &= 2.7 \text{ to } 3.6 \text{ V case of } f_{\text{FPH}} = 27 \text{ MHz} \\ \text{Vcc} &= 3.0 \text{ to } 3.6 \text{ V case of } f_{\text{FPH}} = 36 \text{ MHz} \end{aligned}$ 

| No. | o. Symbol Parameter |                           | Varia       | ble | f <sub>FPH</sub> = 2<br>(Case: | 27 MHz<br>tm = 0) | f <sub>FPH</sub> = 3<br>(Case: | Unit |    |
|-----|---------------------|---------------------------|-------------|-----|--------------------------------|-------------------|--------------------------------|------|----|
|     |                     |                           | Min         | Max | Min                            | Max               | Min                            | Max  |    |
| 1   | t <sub>DSU</sub>    | Data valid → D1BSCP fall  | x - 20 + tm |     | 17                             |                   | 7.7                            |      | ns |
| 2   | t <sub>DHD</sub>    | D1BSCP fall → Data hold   | x - 5 + tm  |     | 32                             |                   | 22                             |      | ns |
| 3   | tcwH                | D1SBCP → Clock high width | x - 10 + tm |     | 27                             |                   | 17.7                           |      | ns |
| 4   | t <sub>CWL</sub>    | D1BSCP → Clock low width  | x - 10 + tm |     | 27                             |                   | 17.7                           |      | ns |
| 5   | t <sub>CW</sub>     | D1BSCP → Clock cycle      | 2x + 2tm    |     | 27                             |                   | 55.4                           |      | ns |

$$tm = (2^{SCPW} - 1) X$$

SCPW: Setting of (LCDMODE)<SCPW1:0>

X: 1/f<sub>FPH</sub>

Example: If SCPW = 3 (8 clock mode),  $f_{FPH} = 36$  [MHz]

 $tm = (2^3 - 1) * 1/36 MHz = 194.4 [ns]$ 

Table 4.9.1 tm at  $f_{FPH} = 36$  [MHz]

| SCP Width | <scpw1:0></scpw1:0> | tm       |
|-----------|---------------------|----------|
| Base SCP  | 00                  | 0 ns     |
| 2 clocks  | 01                  | 27.77 ns |
| 4 clocks  | 10                  | 83.31 ns |
| 8 clocks  | 11                  | 194.4 ns |

## 4.10 Recommended Crystal Oscillation Circuit

TMP91C820A is evaluated by below oscillator vender. When selecting external parts, make use of this information.

Note: Total loads value of oscillator is sum of external loads (C1 and C2) and floating loads of actual assemble board. There is a possibility of miss operating using C1 and C2 value in below table. When designing board, it should design minimum length pattern around oscillator. And we recommend that oscillator evaluation try on your actual using board.

## (1) Connection example



High-frequency oscillator



Low-frequency oscillator

(2) TMP91C820A recommended ceramic oscillator: Murata Manufacturing Co., Ltd.

Circuit parameter recommended

|             | Oscillation        | Item of Oscillator                   | Pai        | rameter    | of Eleme  | ents      | Running Condition    |            |  |
|-------------|--------------------|--------------------------------------|------------|------------|-----------|-----------|----------------------|------------|--|
| MCU         | Frequency<br>[MHZ] | Upper: Old<br>Lower: New             | C1<br>[pF] | C2<br>[pF] | Rf<br>[Ω] | Rd<br>[Ω] | Voltage of Power [V] | Tc [°C]    |  |
|             | 2.00               | CSTLS2M00G56-B0                      | (47)       | (47)       | Open      | 0         |                      |            |  |
|             | 2.50               | CSTLS2M50G56-B0                      | (47)       | (47)       | Open      | 0         |                      |            |  |
| TMP91C820A  | 10.00              | CSTS1000MG03<br>*CSTLS10M0G53-B0     | (15)       | (15)       | Open      | 0         | 1.8 to 2.2           | -40 to +85 |  |
| TIMP91C620A | 12.50              | CSA12.5MTZ093<br>*CSALA12M5T55093-B0 | 30         | 30         | Open      | 0         | 1.0 10 2.2           | -40 i0 +85 |  |
|             | 12.50              | CST12.0MTW093<br>*CSTLA12M5T55093-B0 | (30)       | (30)       | Open      | 0         |                      |            |  |

|            | Oscillation | Item of Oscillator               | Pa   | rameter | of Eleme | ents | Running    | Condition  |  |
|------------|-------------|----------------------------------|------|---------|----------|------|------------|------------|--|
| MCU        | Frequency   | Upper: Old                       | C1   | C2      | Rf       | Rd   | Voltage of | Tc [°C]    |  |
|            | [MHz]       | Lower: New                       | [pF] | [pF]    | [Ω]      | [Ω]  | Power [V]  | 10[0]      |  |
|            | 4.00        | CSTS0400MG06<br>*CSTLS4M00G56-B0 | (47) | (47)    | Open     | 0    |            |            |  |
|            | 6.750       | CSTS0675MG06<br>*CSTLS6M75G56-B0 | (47) | (47)    | Open     | 0    |            |            |  |
|            | 12.50       | CSA12.5MTZ<br>*CSALA12M5T55-B0   | 30   | 30      | Open     | 0    | 07.00      | 40.4 05    |  |
| TMP91C820A | 12.50       | CST12.0MTW<br>*CSTLA12M5T55-B0   | (30) | (30)    | Open     | 0    | 2.7 to 3.6 | -40 to +85 |  |
|            | 20.00       | CSALS20M0X53-B0                  | 5    | 5       | Open     | 0    |            |            |  |
|            | 20.00       | CSTLS20M0X51-B0                  | (5)  | (5)     | Open     | 0    |            | i          |  |
|            | 27.00       | CSALS27M0X51-B0                  | Open | Open    | 10K      | 0    |            |            |  |
|            | 32.00       | CSALA32M0X51-B0                  | 3    | 3       | Open     | 0    |            |            |  |

Note: In CST \*\*\*type oscillator, capacitance C1, C2 is built in.

• The product numbers and specifications of the resonators by Murata Manufacturing Co., Ltd. are subject to change. For up-to-date information, please refer to the following URL: http://www.murata.co.jp/search/index.html

## 5. Table of SFRs

The special function registers (SFRs) include the I/O ports and peripheral control registers allocated to the 4-Kbyte address space from 000000H to 000FFFH.

- (1) I/O ports
- (2) I/O port control
- (3) Interrupt control
- (4) Chip select/wait control
- (5) Clock gear
- (6) DFM (Clock doubler)
- (7) 8-bit timer
- (8) UART/serial channel
- (9) I2C bus/serial interface
- (10) AD converter
- (11) Watchdog timer
- (12) RTC (Real time clock)
- (13) Melody/alarm generator
- (14) MMU
- (15) LCD controller
- (16) SDRAM controller
- (17) 16-bit timer

#### Table layout

| Symbol | Name | Address | 7 | 6 |        | // |   | 1 | 0 |                             |
|--------|------|---------|---|---|--------|----|---|---|---|-----------------------------|
|        |      |         |   |   | $\Box$ | 7, |   |   |   | → Bit symbol                |
|        |      |         |   |   |        | // | \ |   |   | → Read/Write                |
|        |      |         |   |   |        | 7  | П |   |   | → Initial value after reset |
|        |      |         |   |   |        | 7/ |   |   |   | → Remarks                   |
|        |      |         |   |   |        |    |   |   |   |                             |

Note: "Prohibit RMW" in the table means that you cannot use RMW instructions on these register.

Example: When setting bit0 only of the register PxCR, the instruction "SET 0, (PxCR)" cannot be used. The LD (Transfer) instruction must be used to write all eight bits.

#### Read/write

R/W: Both read and write are possible.

R: Only read is possible.

W: Only write is possible.

W\*: Both read and write are possible (when this bit is read as 1).

Prohibit RMW: Read-modify-write instructions are prohibited. (The EX, ADD, ADC, BUS, SBC, INC, DEC, AND, OR, XOR, STCF, RES, SET, CHG, TSET, RLC, RRC, RL, RR, SLA, SRA, SLL, SRL, RLD and RRD instruction are

read-modify-write instructions.)

R/W\*: Read-modify-write is prohibited when controlling the pull-up resistor.

Table 5.1 SFR Address Map (1/4)

[1], [2] PORT

| Address | Name |
|---------|------|
| 0000H   | P0   |
| 1H      | P1   |
| 2H      | P0CR |
| 3H      |      |
| 4H      | P1CR |
| 5H      | P1FC |
| 6H      | P2   |
| 7H      | P3   |
| 8H      | P2CR |
| 9H      | P2FC |
| AH      | P3CR |
| ВН      | P3FC |
| CH      | P4   |
| DH      | P5   |
| EH      | P4CR |
| FH      | P4FC |

| Address | Name  |
|---------|-------|
| 0010H   | P5CR  |
| 1H      |       |
| 2H      | P6    |
| 3H      | P7    |
| 4H      |       |
| 5H      | P6FC  |
| 6H      | P7CR  |
| 7H      | P7FC  |
| 8H      | P8    |
| 9H      | P9    |
| AH      |       |
| ВН      | P6FC2 |
| CH      | P7FC2 |
| DH      | P9FC  |
| EH      | PA    |
| FH      | P7ODE |

| Address | Name  |
|---------|-------|
| 0020H   |       |
| 1H      | PAFC  |
| 2H      | PB    |
| 3H      | PC    |
| 4H      | PBCR  |
| 5H      | PBFC  |
| 6H      | PCCR  |
| 7H      | PCFC  |
| 8H      | PCODE |
| 9H      | PD    |
| AH      | PDFC  |
| ВН      | PBODE |
| СН      | PE    |
| DH      | PECR  |
| EH      | PEFC  |
| FH      |       |

| Address | Name |
|---------|------|
| 0030H   | PF   |
| 1H      |      |
| 2H      | PFFC |
| 3H      |      |
| 4H      |      |
| 5H      |      |
| 6H      |      |
| 7H      |      |
| 8H      |      |
| 9H      |      |
| AH      |      |
| ВН      |      |
| CH      |      |
| DH      |      |
| EH      |      |
| FH      |      |

| Address | Name   |
|---------|--------|
|         | rtanic |
| 0070H   |        |
| 1H      |        |
| 2H      |        |
| 3H      |        |
| 4H      |        |
| 5H      |        |
| 6H      |        |
| 7H      |        |
| 8H      |        |
| 9H      |        |
| AH      |        |
| ВН      |        |
| СН      |        |
| DH      | PZ     |
| EH      | PZCR   |
| FH      | PZFC   |

[3] INTC

| Address | Name   |
|---------|--------|
| 0080H   | DMA0V  |
| 1H      | DMA1V  |
| 2H      | DMA2V  |
| 3H      | DMA3V  |
| 4H      |        |
| 5H      |        |
| 6H      |        |
| 7H      |        |
| 8H      | INTCLR |
| 9H      | DMAR   |
| AH      | DMAB   |
| ВН      |        |
| СН      | IIMC   |
| DH      |        |
| EH      |        |
| FH      |        |

| Address | Name       |
|---------|------------|
| 0090H   | INTE0AD    |
| 1H      | INTE12     |
| 2H      | INTE3ALM4  |
| 3H      | INTEALM01  |
| 4H      | INTEALM23  |
| 5H      | INTETA01   |
| 6H      | INTETA23   |
| 7H      | INTERTCKEY |
| 8H      | INTES0     |
| 9H      | INTES1     |
| AH      | INTES2LCD  |
| ВН      | INTETC01   |
| СН      | INTETC23   |
| DH      | INTEP01    |
| EH      | Reserved   |
| FH      | Reserved   |

| Address | Name    |
|---------|---------|
| 00A0H   | INTES3  |
| 1H      | INTETB0 |
| 2H      |         |
| 3H      |         |
| 4H      |         |
| 5H      |         |
| 6H      |         |
| 7H      |         |
| 8H      |         |
| 9H      |         |
| AH      |         |
| ВН      |         |
| CH      |         |
| DH      |         |
| EH      |         |
| FH      |         |

Note: Do not access to the unnamed addresses (e.g., addresses to which no register has been allocated).

Table 5.2 SFR Address Map (2/4)

[5], [6] CGEAR, DFM

## [4] CS/WAIT

| [1] 00/11/11 |       |
|--------------|-------|
| Address      | Name  |
| 00C0H        | B0CS  |
| 1H           | B1CS  |
| 2H           | B2CS  |
| 3H           | B3CS  |
| 4H           |       |
| 5H           |       |
| 6H           |       |
| 7H           | BEXCS |
| 8H           | MSAR0 |
| 9H           | MAMR0 |
| AH           | MSAR1 |
| ВН           | MAMR1 |
| CH           | MSAR2 |
| DH           | MAMR2 |
| EH           | MSAR3 |
| FH           | MAMR3 |

| Address | Name   |
|---------|--------|
| 00E0H   | SYSCR0 |
| 1H      | SYSCR1 |
| 2H      | SYSCR2 |
| 3H      | EMCCR0 |
| 4H      | EMCCR1 |
| 5H      | EMCCR2 |
| 6H      | EMCCR3 |
| 7H      |        |
| 8H      | DFMCR0 |
| 9H      | DFMCR1 |
| AH      |        |
| ВН      |        |
| СН      |        |
| DH      |        |
| EH      |        |
| FH      |        |

## [7] TMRA

| Address | Name     |
|---------|----------|
| 0100H   | TA01RUN  |
| 1H      |          |
| 2H      | TA0REG   |
| 3H      | TA1REG   |
| 4H      | TA01MOD  |
| 5H      | TA01FFCR |
| 6H      |          |
| 7H      |          |
| 8H      | TA23RUN  |
| 9H      |          |
| AH      | TA2REG   |
| BH      | TA3REG   |
| СН      | TA23MOD  |
| DH      | TA3FFCR  |
| EH      |          |
| FH      |          |

## [8] UART/SIO

| Address | Name    |
|---------|---------|
| 0200H   | SC0BUF  |
| 1H      | SC0CR   |
| 2H      | SC0MOD0 |
| 3H      | BR0CR   |
| 4H      | BR0ADD  |
| 5H      | SC0MOD1 |
| 6H      |         |
| 7H      | SIRCR   |
| 8H      | SC1BUF  |
| 9H      | SC1CR   |
| AH      | SC1MOD0 |
| вн      | BR1CR   |
| СН      | BR1ADD  |
| DH      | SC1MOD1 |
| EH      |         |
| FH      |         |

| Address | Name    |
|---------|---------|
|         |         |
| 0210H   | SC2BUF  |
| 1H      | SC2CR   |
| 2H      | SC2MOD0 |
| 3H      | BR2CR   |
| 4H      | BR2ADD  |
| 5H      | SC2MOD1 |
| 6H      |         |
| 7H      |         |
| 8H      |         |
| 9H      |         |
| AH      |         |
| BH      |         |
| СН      |         |
| DH      |         |
| EH      |         |
| FH      |         |

[9] I2C bus/SIO

| [9] I C bus/o | 10             |
|---------------|----------------|
| Address       | Name           |
| 0240H         | SBI0CR1        |
| 1H            | SBI0DBR        |
| 2H            | I2C0AR         |
| 3H            | SBI0CR2/SBI0SR |
| 4H            | SBI0BR0        |
| 5H            | SBI0BR1        |
| 6H            |                |
| 7H            |                |
| 8H            |                |
| 9H            |                |
| AH            |                |
| вн            |                |
| СН            |                |
| DH            |                |
| EH            |                |
| FH            |                |

Note: Do not access to the unnamed addresses (e.g., addresses to which no register has been allocated).

Table 5.3 SFR Address Map (3/4)

[10] 10-bit ADC

| [10] 10-bit ADC |          |
|-----------------|----------|
| Address         | Name     |
| 02A0H           | ADREG04L |
| 1H              | ADREG04H |
| 2H              | ADREG15L |
| 3H              | ADREG15H |
| 4H              | ADREG26L |
| 5H              | ADREG26H |
| 6H              | ADREG37L |
| 7H              | ADREG37H |
| 8H              |          |
| 9H              |          |
| AH              |          |
| BH              |          |
| CH              |          |
| DH              |          |
| EH              |          |
| FH              |          |

| Address | Name   |
|---------|--------|
| 02B0H   | ADMOD0 |
| 1H      | ADMOD1 |
| 2H      |        |
| 3H      |        |
| 4H      |        |
| 5H      |        |
| 6H      |        |
| 7H      |        |
| 8H      |        |
| 9H      |        |
| AH      |        |
| ВН      |        |
| СН      |        |
| DH      |        |
| EH      |        |
| FH      |        |

[11] WDT

| וטייי [וון |       |
|------------|-------|
| Address    | Name  |
| 0300H      | WDMOD |
| 1H         | WDCR  |
| 2H         |       |
| 3H         |       |
| 4H         |       |
| 5H         |       |
| 6H         |       |
| 7H         |       |
| 8H         |       |
| 9H         |       |
| AH         |       |
| BH         |       |
| CH         |       |
| DH         |       |
| EH         |       |
| FH         |       |

[12] RTC

| Address | Name   |
|---------|--------|
| 0320H   | SECR   |
| 1H      | MINR   |
| 2H      | HOURR  |
| 3H      | DAYR   |
| 4H      | DATER  |
| 5H      | MONTHR |
| 6H      | YEARR  |
| 7H      | PAGER  |
| 8H      | RESTR  |
| 9H      |        |
| AH      |        |
| ВН      |        |
| СН      |        |
| DH      |        |
| EH      |        |
| FH      |        |

[13] MLD

| Address | Name    |
|---------|---------|
| 0330H   | ALM     |
| 1H      | MELALMC |
| 2H      | MELFL   |
| 3H      | MELFH   |
| 4H      | ALMINT  |
| 5H      |         |
| 6H      |         |
| 7H      |         |
| 8H      |         |
| 9H      |         |
| AH      |         |
| BH      |         |
| СН      |         |
| DH      |         |
| EH      |         |
| FH      |         |

[14] MMU

| Address | Name   |
|---------|--------|
| 0350H   | LOCAL0 |
| 1H      | LOCAL1 |
| 2H      | LOCAL2 |
| 3H      | LOCAL3 |
| 4H      |        |
| 5H      |        |
| 6H      |        |
| 7H      |        |
| 8H      |        |
| 9H      |        |
| AH      |        |
| ВН      |        |
| СН      |        |
| DH      |        |
| EH      |        |
| FH      |        |

Note: Do not access to the unnamed addresses (e.g., addresses to which no register has been allocated).

TOSHIBA TMP91C820A

Table 5.4 SFR Address Map (4/4)

[15] LCDC

| [10] 2020 |         |
|-----------|---------|
| Address   | Name    |
| 04B0H     | LCDMODE |
| 1H        | LCDDVM  |
| 2H        | LCDSIZE |
| 3H        | LCDCTL  |
| 4H        | LCDFFP  |
| 5H        | LCDGL   |
| 6H        | LCDCM   |
| 7H        | LCDCW   |
| 8H        | LCDCH   |
| 9H        | LCDCP   |
| AH        | LCDCPL  |
| BH        | LCDCPM  |
| CH        | LCDCPH  |
| DH        |         |
| EH        |         |
| FH        |         |

| Address | Name   |
|---------|--------|
| 04C0H   | LSARAM |
| 1H      | LSARAH |
| 2H      | LEARAM |
| 3H      | LEARAH |
| 4H      | LSARBM |
| 5H      | LSARBH |
| 6H      | LEARBM |
| 7H      | LEARBH |
| 8H      | LSARCL |
| 9H      | LSARCM |
| AH      | LSARCH |
| BH      |        |
| СН      |        |
| DH      |        |
| EH      |        |
| FH      |        |

| Address | Name |
|---------|------|
| 04D0H   | LG0L |
| 1H      | LG0H |
| 2H      | LG1L |
| 3H      | LG1H |
| 4H      | LG2L |
| 5H      | LG2H |
| 6H      | LG3L |
| 7H      | LG3H |
| 8H      | LG4L |
| 9H      | LG4H |
| AH      | LG5L |
| BH      | LG5H |
| CH      | LG6L |
| DH      | LG6H |
| EH      | LG7L |
| FH      | LG7H |

| Address | Name |
|---------|------|
| 04E0H   | LG8L |
| 1H      | LG8H |
| 2H      | LG9L |
| 3H      | LG9H |
| 4H      | LGAL |
| 5H      | LGAH |
| 6H      | LGBL |
| 7H      | LGBH |
| 8H      | LGCL |
| 9H      | LGCH |
| AH      | LGDL |
| ВН      | LGDH |
| СН      | LGEL |
| DH      | LGEH |
| EH      | LGFL |
| FH      | LGFH |

[16] SDRAMC

| [10] 0210 0010 |       |
|----------------|-------|
| Address        | Name  |
| 04F0H          | SDACR |
| 1H             | SDRCR |
| 2H             |       |
| 3H             |       |
| 4H             |       |
| 5H             |       |
| 6H             |       |
| 7H             |       |
| 8H             |       |
| 9H             |       |
| AH             |       |
| ВН             |       |
| СН             |       |
| DH             |       |
| EH             |       |
| FH             |       |

[17] TMRB

| Address | Name    |
|---------|---------|
| 0180H   | TB0RUN  |
| 1H      |         |
| 2H      | TB0MOD  |
| 3H      | TB0FFCR |
| 4H      |         |
| 5H      |         |
| 6H      |         |
| 7H      |         |
| 8H      | TB0RG0L |
| 9H      | TB0RG0H |
| AH      | TB0RG1L |
| ВН      | TB0RG1H |
| CH      | TB0CP0L |
| DH      | TB0CP0H |
| EH      | TB0CP1L |
| FH      | TB0CP1H |

Note: Do not access to the unnamed addresses (e.g., address to which no register has been allocated).

(1) I/O ports (1/2)

| Symbol   | Name    | Address            | 7                                                                | 6                                                                | 5           | 4             | 3                          | 2              | 1        | 0    |  |  |
|----------|---------|--------------------|------------------------------------------------------------------|------------------------------------------------------------------|-------------|---------------|----------------------------|----------------|----------|------|--|--|
| Cyllidal | INAIIIE | Addiess            | P07                                                              | P06                                                              | P05         | P04           | P03                        | P02            | P01      | P00  |  |  |
| P0       | PORT0   | 00H                | 107                                                              | 1 00                                                             | 1 03        |               | W                          | 1 02           | 101      | 1 00 |  |  |
| . •      | . 5     |                    | Data from external port (Output latch register is cleared to 0.) |                                                                  |             |               |                            |                |          |      |  |  |
|          |         |                    | P17                                                              | P16                                                              | P15         | P14           | P13                        | P12            | P11      | P10  |  |  |
| P1       | PORT1   | 01H                |                                                                  | 1 10                                                             | 1 10        |               | /W                         | , ,_           |          | 1 10 |  |  |
|          |         |                    |                                                                  | Data from external port (Output latch register is cleared to 0.) |             |               |                            |                |          |      |  |  |
|          |         |                    | P27                                                              | P26                                                              | P25         | P24           | P23                        | P22            | P21      | P20  |  |  |
| P2       | PORT2   | 06H                |                                                                  |                                                                  | . 20        |               | /W                         |                |          | 0    |  |  |
|          |         |                    |                                                                  | Data fi                                                          | rom externa | l port (Outpu | ıt latch regis             | ter is cleare  | d to 0.) |      |  |  |
|          |         |                    | P37                                                              | P36                                                              | P35         | P34           | P33                        | P32            | P31      | P30  |  |  |
| P3       | PORT3   | 07H                |                                                                  | ı                                                                |             | R/            | W                          |                | I        | I    |  |  |
|          |         |                    |                                                                  | Data fi                                                          | rom externa | l port (Outpu | ıt latch regis             | ter is cleare  | d to 0.) |      |  |  |
|          |         |                    | P47                                                              | P46                                                              | P45         | P44           | P43                        | P42            | P41      | P40  |  |  |
| P4       | PORT4   | 0CH                |                                                                  |                                                                  |             | R/            | W                          |                | 1        | _    |  |  |
|          |         |                    |                                                                  | Data fi                                                          | rom externa |               | it latch regis             | ter is cleare  | d to 0.) |      |  |  |
|          |         |                    |                                                                  |                                                                  |             |               | PZ3                        | PZ2            | PZ1      | PZ0  |  |  |
|          |         |                    |                                                                  |                                                                  |             |               |                            | l              | W        | 1    |  |  |
|          |         |                    |                                                                  |                                                                  |             |               | Data fron                  | n external     |          |      |  |  |
| D.7      | DODT7   | 7DH                |                                                                  |                                                                  |             |               |                            | tput latch     | 1        | 1    |  |  |
| PZ       | PORTZ   | (Prohibit<br>RMW*) |                                                                  |                                                                  |             |               |                            | set to 1.)     |          |      |  |  |
|          |         | TXIVIVV ')         |                                                                  |                                                                  |             |               | 0 (Output la Pull-up resis | tch register): |          |      |  |  |
|          |         |                    |                                                                  |                                                                  |             |               | · ·                        | ch register):  | -        | =    |  |  |
|          |         |                    |                                                                  |                                                                  |             |               | Pull-up resis              |                |          |      |  |  |
|          |         |                    |                                                                  | P56                                                              |             |               |                            |                |          |      |  |  |
|          |         |                    |                                                                  | R/W                                                              |             |               |                            |                |          |      |  |  |
|          |         |                    |                                                                  | Data from                                                        |             |               |                            |                |          |      |  |  |
|          |         | ODII               |                                                                  | external port                                                    |             |               |                            |                |          |      |  |  |
| P5       | PORT5   | 0DH<br>(Prohibit   |                                                                  | (Output latch                                                    |             |               |                            |                |          |      |  |  |
|          | 1 01(13 | RMW*)              |                                                                  | register is                                                      |             |               |                            |                |          |      |  |  |
|          |         | ,                  | \                                                                | set to 1.)                                                       |             | \             | \                          |                | \        | \    |  |  |
|          |         |                    |                                                                  | 0(Output late<br>Pull-up resis                                   |             |               |                            |                |          |      |  |  |
|          |         |                    |                                                                  | 1(Output late                                                    |             |               |                            |                |          |      |  |  |
|          |         |                    |                                                                  | Pull-up resis                                                    | tor ON      |               |                            |                |          |      |  |  |
|          |         |                    | P67                                                              | P66                                                              | P65         | P64           | P63                        | P62            | P61      | P60  |  |  |
| P6       | PORT6   | 12H                |                                                                  | _                                                                | 1           | 1             | /W                         | 1              | 1        | 1    |  |  |
|          |         |                    | 1                                                                | 1                                                                | 1           | 1             | 1                          | 0              | 1        | 1    |  |  |
|          |         |                    | P77                                                              | P76                                                              | P75         | P74           | P73                        | P72            | P71      | P70  |  |  |
| P7       | PORT7   | 13H                |                                                                  |                                                                  |             |               | W                          |                |          |      |  |  |
|          |         |                    |                                                                  | 1                                                                |             |               | put latch reg              |                |          | ı    |  |  |
|          | _       |                    | P87                                                              | P86                                                              | P85         | P84           | P83                        | P82            | P81      | P80  |  |  |
| P8       | PORT8   | 18H                |                                                                  |                                                                  |             |               | 7                          |                |          |      |  |  |
|          |         |                    |                                                                  |                                                                  |             |               | external port              |                | ı        | ı    |  |  |
|          | _       |                    | P97                                                              | P96                                                              | P95         | P94           | P93                        | P92            | P91      | P90  |  |  |
| P9       | PORT9   | 9 19H              |                                                                  |                                                                  |             |               | 3                          |                |          |      |  |  |
|          |         |                    |                                                                  |                                                                  | ı           |               | external port              |                | 1        | 1    |  |  |
|          |         |                    | PA7                                                              | PA6                                                              | PA5         | PA4           | PA3                        | PA2            | PA1      | PA0  |  |  |
| PA       | PORTA   | 1EH                |                                                                  | 1                                                                |             | R/            | W                          | t .            | <u> </u> | ·    |  |  |
|          |         |                    | 1                                                                | 1                                                                | 1           | 1             | 1                          | 1              | 1        | 1    |  |  |
|          |         |                    |                                                                  |                                                                  |             |               |                            |                |          |      |  |  |

I/O ports (2/2)

| Symbol | Name  | Address | 7   | 6           | 5                       | 4                      | 3              | 2                          | 1                                     | 0         |     |     |     |    |   |  |  |  |     |  |
|--------|-------|---------|-----|-------------|-------------------------|------------------------|----------------|----------------------------|---------------------------------------|-----------|-----|-----|-----|----|---|--|--|--|-----|--|
|        |       |         |     | PB6         | PB5                     | PB4                    | PB3            |                            | PB1                                   | PB0       |     |     |     |    |   |  |  |  |     |  |
|        |       |         |     |             | R/                      | W                      |                |                            | R/                                    | W         |     |     |     |    |   |  |  |  |     |  |
| PB     | PORTB | 22H     |     | Data from 6 | external port<br>set to | (Output latch<br>o 1.) | n register is  |                            | Data from<br>port (Out<br>register is | put latch |     |     |     |    |   |  |  |  |     |  |
|        |       |         |     |             | PC5                     | PC4                    | PC3            | PC2                        | PC1                                   | PC0       |     |     |     |    |   |  |  |  |     |  |
| PC     | PORTC | 23H     |     |             |                         |                        | R/             | W                          |                                       |           |     |     |     |    |   |  |  |  |     |  |
|        |       |         |     |             | Data                    | a from exterr          | put latch regi | tch register is set to 1.) |                                       |           |     |     |     |    |   |  |  |  |     |  |
|        |       | 29H     | PD7 | PD6         |                         | PD4                    | PD3            | PD2                        | PD1                                   | PD0       |     |     |     |    |   |  |  |  |     |  |
| PD     | PORTD |         | 29H | 29H         | 29H                     | 29H                    | 29H            | 29H                        | 29H                                   | 29H       | 29H | 29H | 29H | R/ | W |  |  |  | R/W |  |
|        |       |         | 1   | 1           |                         | 1                      | 1              | 1                          | 1                                     | 1         |     |     |     |    |   |  |  |  |     |  |
|        |       |         | PE7 | PE6         | PE5                     | PE4                    | PE3            | PE2                        | PE1                                   | PE0       |     |     |     |    |   |  |  |  |     |  |
| PE     | PORTE | 2CH     |     |             |                         | R/                     | W              |                            |                                       |           |     |     |     |    |   |  |  |  |     |  |
|        |       |         |     | Data        | a from exterr           | nal port (Outp         | out latch reg  | ister is set to            | 1.)                                   |           |     |     |     |    |   |  |  |  |     |  |
|        |       |         | PF7 | PF6         | PF5                     | PF4                    | PF3            | PF2                        | PF1                                   | PF0       |     |     |     |    |   |  |  |  |     |  |
| PF     | PORTF | 30H     | R/W |             |                         |                        |                |                            |                                       |           |     |     |     |    |   |  |  |  |     |  |
|        |       |         | 1   | 1           | 1                       | 1                      | 1              | 1                          | 1                                     | 1         |     |     |     |    |   |  |  |  |     |  |

## (2) I/O port control (1/4)

|        | Name      | Address           | 7    | 6          | 5     | 4             | 3              | 2     | 1          | 0    |
|--------|-----------|-------------------|------|------------|-------|---------------|----------------|-------|------------|------|
|        |           |                   | P07C | P06C       | P05C  | P04C          | P03C           | P02C  | P01C       | P00C |
| P0CR   | PORT0     | 02H               |      | •          |       | V             | V              |       | •          |      |
| PUCK   | control   | (Prohibit<br>RMW) | 0    | 0          | 0     | 0             | 0              | 0     | 0          | 0    |
|        |           |                   |      |            |       | 0: Input      | 1: Output      |       |            |      |
|        |           | 0.41.1            | P17C | P16C       | P15C  | P14C          | P13C           | P12C  | P11C       | P10C |
| P1CR   | PORT1     | 04H<br>(Prohibit  |      |            |       | V             | V              |       |            |      |
| I TOIX | control   | RMW)              | 0    | 0          | 0     | 0             | 0              | 0     | 0          | 0    |
|        |           | ,                 |      |            |       | 0: Input      | 1: Output      |       |            |      |
|        |           | 0511              | P17F | P16F       | P15F  | P14F          | P13F           | P12F  | P11F       | P10F |
| P1FC   | PORT1     | 05H<br>(Prohibit  |      |            |       | V             | N              |       |            |      |
| 1 11 0 | function  | RMW)              | 0/1  | 0/1        | 0/1   | 0/1           | 0/1            | 0/1   | 0/1        | 0/1  |
|        |           | ,                 |      |            | 0: P  | ort, 1: Data  | bus (D15 to    | D8)   |            |      |
|        |           | ∩o⊔               | P27C | P26C       | P25C  | P24C          | P23C           | P22C  | P21C       | P20C |
| P2CR   | PORT2 08H | (Prohibit         |      |            |       |               | N              |       |            |      |
| 12010  | control   | RMW)              | 0/1  | 0/1        | 0/1   | 0/1           | 0/1            | 0/1   | 0/1        | 0/1  |
|        |           | ĺ                 |      |            |       | 0: Input      | 1: Output      |       |            |      |
|        |           | 09H               | P27F | P26F       | P25F  | P24F          | P23F           | P22F  | P21F       | P20F |
| P2FC   | PORT2     | (Prohibit         |      |            |       | \             | N              |       |            |      |
| 0      | function  | RMW)              | 0/1  | 0/1        | 0/1   | 0/1           | 0/1            | 0/1   | 0/1        | 0/1  |
|        |           |                   |      |            |       | t, 1: Addres  | s bus (A23 to  |       |            |      |
|        |           | 0AH               | P37C | P36C       | P35C  | P34C          | P33C           | P32C  | P31C       | P30C |
| P3CR   | PORT3     | (Prohibit         |      | 1          | 1     |               | N              | T     | 1          | T    |
|        | control   | RMW)              | 0/1  | 0/1        | 0/1   | 0/1           | 0/1            | 0/1   | 0/1        | 0/1  |
|        |           |                   |      | 1          | 1     | 0: Input      | 1: Output      | 1     | 1          | 1    |
|        |           | 0BH               | P37F | P36F       | P35F  | P34F          | P33F           | P32F  | P31F       | P30F |
| P3FC   | PORT3     | (Prohibit         |      | 1          | 1     |               | N              | T     | 1          | T    |
|        | function  | RMW)              | 0/1  | 0/1        | 0/1   | 0/1           | 0/1            | 0/1   | 0/1        | 0/1  |
|        |           |                   |      | 1          |       |               | ss bus (A15 t  | ,     | 1          | T    |
|        |           | 0EH               | P47C | P46C       | P45C  | P44C          | P43C           | P42C  | P41C       | P40C |
| P4CR   | PORT4     | (Prohibit         |      | ı          | 1     |               | N<br>T         | Τ     | ı          | Τ    |
|        | control   | RMW)              | 0/1  | 0/1        | 0/1   | 0/1           | 0/1            | 0/1   | 0/1        | 0/1  |
|        |           |                   |      | 1          | 1     | 0: Input      | 1: Output      | Г     | 1          | Г    |
|        |           | 0FH               | P47F | P46F       | P45F  | P44F          | P43F           | P42F  | P41F       | P40F |
| P4FC   | PORT4     | (Prohibit         |      | <u>.</u> . | 1 _ : |               | N<br>          |       | <u>.</u> . |      |
|        | function  | RMW)              | 0/1  | 0/1        | 0/1   | 0/1           | 0/1            | 0/1   | 0/1        | 0/1  |
|        |           | ,                 |      |            | 0: Po | ort, 1: Addre | ess bus (A7 to | o A0) |            |      |

I/O port control (2/4)

| <u> </u> | =             | control           |                  | _                | _                |                    |                    | 1 6               | 1 .               | _                 |
|----------|---------------|-------------------|------------------|------------------|------------------|--------------------|--------------------|-------------------|-------------------|-------------------|
| Symbol   | Name          | Address           | 7                | 6                | 5                | 4                  | 3                  | 2                 | 1                 | 0                 |
|          |               | 7EH               |                  |                  |                  |                    | PZ3C               | PZ2C              |                   |                   |
| PZCR     | PORTZ         | (Prohibit         |                  |                  |                  |                    | 1                  | W                 |                   |                   |
|          | control       | RMW)              |                  |                  |                  |                    | 0                  | 0                 |                   |                   |
|          |               | ŕ                 |                  |                  |                  |                    | 0: Input           | 1: Output         |                   |                   |
|          |               |                   |                  | P56C             |                  |                    |                    |                   |                   |                   |
|          |               | 10H               |                  | W                |                  |                    |                    |                   |                   |                   |
| P5CR     | PORT5 control | (Prohibit         |                  | 0                |                  |                    |                    |                   |                   |                   |
|          | 00111101      | RMW)              |                  | 0: Input         |                  |                    |                    |                   |                   |                   |
|          |               |                   |                  | 1: Output        |                  |                    |                    |                   |                   |                   |
|          |               |                   |                  |                  |                  |                    | PZ3F               | PZ2F              | PZ1F              | PZ0F              |
|          |               | 7511              |                  |                  |                  |                    |                    | ١                 | N                 | •                 |
| PZFC     | PORTZ         | 7FH               |                  |                  |                  |                    | 0                  | 0                 | 0                 | 0                 |
| FZFC     | function      | (Prohibit<br>RMW) |                  |                  |                  |                    | 0: Port            | 0: Port           | 0: Port           | 0: Port           |
|          |               | TXIVIVV)          |                  |                  |                  |                    | 1: R/W,            | 1: HWR            | 1: WR             | 1: RD             |
|          |               |                   |                  |                  |                  |                    | SRWE               |                   |                   |                   |
|          |               |                   | P67F             | P66F             | P65F             | P64F               | P63F               | P62F              | P61F              | P60F              |
|          | 00075         | 15H               |                  |                  |                  | \<br>\             | N                  |                   |                   |                   |
| P6FC     | PORT6         | (Prohibit         | 0                | 0                | 0                | 0                  | 0                  | 0                 | 0                 | 0                 |
|          | function      | `RMW)             | 0: Port          | 0: Port          | 0: Port          | 0: Port            | 0: Port            | 0: Port           | 0: Port           | 0: Port           |
|          |               |                   | 1: SRUB          | 1: SRLB          | 1: EA25          | 1: EA24            | 1: <del>CS3</del>  | 1: <del>CS2</del> | 1: <del>CS1</del> | 1: <del>CS0</del> |
|          |               |                   | P67F2            | P66F2            | P65F2            | P64F2              | -                  | P62F2             | P61F2             | _                 |
|          |               | 1BH               | 10/12            | 1 001 2          | 1 001 2          |                    | N                  | 1 021 2           | 10112             |                   |
|          | PORT6         |                   | 0                | 0                | 0                | 0                  | 0                  | 0                 | 0                 | 0                 |
| P6FC2    | function 2    | (Prohibit         |                  |                  |                  |                    | 0                  |                   |                   | 0                 |
|          |               | RMW)              | 0: <p67f></p67f> | 0: <p66f></p66f> | 0: <p65f></p65f> | 0: <p64f></p64f>   | Always             | 0: <p62f></p62f>  | 0: <p61f></p61f>  | Always            |
|          |               |                   | 1: CS2E          | 1: CS2D          | 1: CS2C          | 1: CS2B            | write "0".         | 1: CS2A           | 1: SDCS           | write "0".        |
|          |               |                   | P77C             | P76C             | P75C             | P74C               | P73C               | P72C              | P71C              | P70C              |
|          | PORT7         | 16H               |                  |                  |                  | V                  | V                  | I                 | I                 |                   |
| P7CR     | control       | (Prohibit         | 0                | 0                | 0                | 0                  | 0                  | 0                 | 0                 | 0                 |
|          |               | RMW)              |                  |                  |                  | 0: Input           | 1: Output          |                   |                   | l                 |
|          |               |                   | P77F             | P76F             | P75F             | P74F               | P73F               | P72F              | P71F              | P70F              |
|          |               |                   |                  |                  |                  |                    | N 1 7 31           | 1                 | 1                 | 1 7 01            |
|          |               | 17H               | 0                | 0                | 0                | 0                  | 0                  | 0                 | 0                 | 0                 |
| P7FC     | PORT7         | (Prohibit         |                  | MSK logic        |                  | 0: Port            | 0: Port            | 0: Port           | 0: Port           | 0: Port           |
|          | function      | RMW)              | 1: VEECLK        |                  | 0.1011           | J. 1 UIL           | 0.101              | 1: SCL            | 1: SDA/SO         | 1: SCK            |
|          |               |                   | VLLOLN           | 0: CLK by 1      |                  |                    |                    | 1. 50L            | 557/50            | 1. 5010           |
|          |               |                   |                  | 1: CLK by 0      |                  |                    |                    |                   |                   |                   |
|          |               |                   | -                | -                | P75F2            | P74F2              | P73F2              | -                 | P71F2             | P70F2             |
|          |               |                   |                  | 1                | 1                | l .                | N                  | I .               | 1                 | 1                 |
|          |               |                   | 0                | 0                | 0                | 0                  | 0                  | 0                 | 0                 | 0                 |
|          |               | 1CH               | Always           | Always           | 0: <p75f></p75f> | 0: <p74f></p74f>   | 0: <p73f></p73f>   | Always            | 0: <p71f></p71f>  | SIO0/RXD0         |
| P7FC2    | PORT7         | (Prohibit         | write "0".       | write "0".       | 1: CSEXA         | 1: <del>CS2G</del> | 1: <del>CS2F</del> | write "0".        | 1: OPTTX0         | PIN               |
| 02       | function 2    | RMW)              |                  |                  |                  |                    |                    |                   |                   | SELECT            |
|          |               | ,                 |                  |                  |                  |                    |                    |                   |                   | 0: RXD0           |
|          |               |                   |                  |                  |                  |                    |                    |                   |                   | (PC1)             |
|          |               |                   |                  |                  |                  |                    |                    |                   |                   | 1: OPTRX0         |
|          |               |                   |                  |                  |                  |                    |                    |                   |                   | (P70)             |

I/O port control (3/4)

| Symbol | -              | Address           | 7             | 6          | 5        | 4            | 3             | 2         | 1                                                                            | 0             |
|--------|----------------|-------------------|---------------|------------|----------|--------------|---------------|-----------|------------------------------------------------------------------------------|---------------|
| Cymbol | Hame           | / taarcoo         | <u> </u>      | _          |          |              |               | ODEP72    | -                                                                            |               |
|        | PORT7          | 1FH               |               | W          |          |              |               |           | l                                                                            |               |
| P7ODE  | open           | (Prohibit         | 0             | 0          |          |              |               | 0         |                                                                              |               |
|        | drain          | RMW)              |               | write "0". |          |              |               | 0: 3 sta  | -                                                                            |               |
|        |                | ,                 | Aiways        | wille o.   |          |              |               |           | Odrain P91F  O PA1F  O PB1C W O O: Input PB1F W O O: Port 1: TA1OUT 1 PC1C O |               |
|        |                |                   | P97F          | P96F       | P95F     | P94F         | P93F          | P92F      |                                                                              | P90F          |
|        | IPAPIGI        | 1DH               |               |            |          |              | V             | . 02.     |                                                                              |               |
| P9FC   | function       | (Prohibit RMW)    | 0             | 0          | 0        | 0            | 0             | 0         | 0                                                                            | 0             |
|        |                | KIVIVV)           |               | I          | 0: Ke    | y-in disable | 1:Key-in e    | nable     |                                                                              | l             |
|        |                |                   | PA7F          | PA6F       | PA5F     | PA4F         | PA3F          | PA2F      | PA1F                                                                         | PA0F          |
|        | PORTA          | 21H               |               |            |          | V            | l             | l         |                                                                              |               |
| PAFC   | function       | (Prohibit<br>RMW) | 0             | 0          | 0        | 0            | 0             | 0         | 0                                                                            | 0             |
|        |                | KIVIVV)           |               | 1          | 0: CMO   | S output 1   | I: Open-drair | output    |                                                                              | ı             |
|        |                |                   |               | PB6C       | PB5C     | PB4C         | PB3C          |           | PB1C                                                                         | PB0C          |
| DD00   | PORTB          | 24H               |               |            | V        | V            |               |           | V                                                                            | V             |
| PBCR   | control        | (Prohibit RMW)    |               | 0          | 0        | 0            | 0             |           | 0                                                                            | 0             |
|        |                | KIVIVV)           |               |            | 0: Input | 1: Output    |               |           | 0: Input                                                                     | 1: Output     |
|        |                |                   |               | PB6F       | PB5F     | PB4F         | PB3F          |           | PB1F                                                                         | PB0F          |
|        |                | 0511              |               |            | V        | V            |               |           | V                                                                            | V             |
| PBFC   | PORTB function | 25H<br>(Prohibit  |               | 0          | 0        | 0            | 0             |           | 0                                                                            | 0             |
| 1 51 0 |                | RMW)              |               | 0: Port    | 0: Port  | 0: Port      | 0: Port       |           | 0: Port                                                                      | 0: Port       |
|        |                | ,                 |               | 1: INT3,   | 1: INT2  | 1: INT1      | 1: INT0       |           | 1: TA1OUT                                                                    | 1: TXD2       |
|        |                |                   |               | TB0OUT0    | TA3OUT   |              |               |           |                                                                              |               |
|        |                |                   |               |            |          |              |               |           |                                                                              | ODEPB0        |
|        | PORTB          | 2BH               |               |            |          |              |               |           |                                                                              | W             |
| PBODE  | open           | (Prohibit         |               |            |          |              |               |           |                                                                              | 0             |
|        | drain          | RMW)              |               |            |          |              |               |           |                                                                              | 0: CMOS       |
|        |                |                   |               |            |          |              |               |           |                                                                              | 1: Open drain |
|        |                |                   |               |            | PC5C     | PC4C         | PC3C          | PC2C      | PC1C                                                                         | PC0C          |
|        | PORTC          | 26H               | $\overline{}$ |            | 1 000    | 1 040        | V             | L         | 1010                                                                         | 1 000         |
| PCCR   | control        | (Prohibit         |               |            | 0        | 0            | 0             | 0         | 0                                                                            | 0             |
|        |                | RMW)              |               |            |          |              | 0: Input      | 1: Output |                                                                              | 1             |
|        |                |                   |               |            | PC5F     |              | PC3F          | PC2F      |                                                                              | PC0F          |
|        |                | 27H               |               |            | W        |              |               | V         |                                                                              | W             |
| PCFC   | PORTC          | (Prohibit         |               |            | 0        |              | 0             | 0         |                                                                              | 0             |
|        | function       | RMW)              |               |            | 0: Port  |              | 0: Port       | 0: Port   |                                                                              | 0: Port       |
|        |                |                   |               |            | 1: SCLK1 |              | 1: TXD1       | 1: SCLK0  |                                                                              | 1: TXD0       |
|        |                |                   |               |            |          |              | ODEPC3        |           |                                                                              | ODEPC0        |
|        | DODTO          | 2011              |               |            |          |              | W             |           |                                                                              | W             |
| PCODE  | PORTC open     | 28H<br>(Prohibit  |               |            |          |              | 0             |           |                                                                              | 0             |
| 1 CODE | drain          | (Pronibit -       |               |            |          |              | 0: CMOS       |           |                                                                              | 0: CMOS       |
|        |                |                   |               |            |          |              | 1: Open       |           |                                                                              | 1: Open       |
|        |                |                   |               |            |          |              | drain         |           |                                                                              | drain         |

TOSHIBA TMP91C820A

## I/O port control (4/4)

| Symbol | Name     | Address                  | 7         | 6                  | 5        | 4           | 3           | 2       | 1        | 0         |  |  |
|--------|----------|--------------------------|-----------|--------------------|----------|-------------|-------------|---------|----------|-----------|--|--|
|        |          |                          | PD7F      | PD6F               |          | PD4F        | PD3F        | PD2F    | PD1F     | PD0F      |  |  |
|        |          | 2AH                      | V         | /                  |          |             |             | W       |          |           |  |  |
| PDFC   | PORTD    | (Prohibit                | 0         | 0                  |          | 0           | 0           | 0       | 0        | 0         |  |  |
| . 5. 6 | function | RMW)                     | 0: Port   | 0: Port            |          | 0: Port     | 0: Port     | 0: Port | 0: Port  | 0: Port   |  |  |
|        |          | ,                        | 1:MLDALM  | 1: ALARM<br>MLDALM |          | 1: DOFFB    | 1: DLEBCD   | 1:D3BFR | 1: D2BLP | 1: D1BSCP |  |  |
|        |          | 0011                     | PE7C      | PE6C               | PE5C     | PE4C        | PE3C        | PE2C    | PE1C     | PE0C      |  |  |
| PECR   | PORTE    | 2DH<br>(Prohibit<br>RMW) |           | W                  |          |             |             |         |          |           |  |  |
| FLOR   | control  |                          | 0         | 0                  | 0        | 0           | 0           | 0       | 0        | 0         |  |  |
|        |          | ,                        |           |                    |          | 0: Input    | 1: Output   |         |          |           |  |  |
|        |          | 0511                     | PE7F      | PE6F               | PE5F     | PE4F        | PE3F        | PE2F    | PE1F     | PE0F      |  |  |
| PEFC   | PORTE    | 2EH<br>(Prohibit         |           | W                  |          |             |             |         |          |           |  |  |
| 1 21 0 | function | RMW)                     | 0         | 0                  | 0        | 0           | 0           | 0       | 0        | 0         |  |  |
|        |          | ,                        |           |                    | 0: Por   | t 1: LD7 to | LD0 for LCD | driver  |          |           |  |  |
|        |          |                          | =         | PF6F               | PF5F     | PF4F        | PF3F        | PF2F    | PF1F     | PF0F      |  |  |
|        | PORTF    | 32H                      |           |                    |          | V           | 1           |         |          |           |  |  |
| PFFC   | function | (Prohibit                | 0         | 1                  | 0        | 0           | 0           | 0       | 0        | 0         |  |  |
|        |          | RMW)                     | Always    | 0: Port            | 0: Port  | 0: Port     | 0: Port     | 0: Port | 0: Port  | 0: Port   |  |  |
|        |          |                          | write"0". | 1: SDCLK           | 1: SDCKE | 1: SDUDQM   | 1: SDLDQM   | 1: SDWE | 1: SDCAS | 1: SDRAS  |  |  |

## (3) Interrupt control (1/3)

| Symbol     | Name                | Address | 7         | 6      | 5              | 4      | 3         | 2      | 1             | 0      |
|------------|---------------------|---------|-----------|--------|----------------|--------|-----------|--------|---------------|--------|
|            |                     |         |           | INI    | ΓAD            |        |           | IN     | T0            |        |
|            | Interrupt<br>enable |         | IADC      | IADM2  | IADM1          | IADM0  | IOC       | I0M2   | IOM1          | IOMO   |
| INTE0AD    | 0 and               | 90H     | R         |        | R/W            |        | R         |        | R/W           |        |
|            | AD                  |         | 0         | 0      | 0              | 0      | 0         | 0      | 0             | 0      |
|            |                     |         | 1: INTAD  | ı      | Interrupt leve | el     | 1: INT0   | I      | nterrupt leve | l      |
|            |                     |         |           | IN     | T2             |        |           | IN     | T1            |        |
|            | Interrupt           |         | I2C       | I2M2   | I2M1           | I2M0   | I1C       | I1M2   | I1M1          | I1M0   |
| INTE12     | enable              | 91H     | R         |        | R/W            |        | R         |        | R/W           |        |
|            | 2/1                 |         | 0         | 0      | 0              | 0      | 0         | 0      | 0             | 0      |
|            |                     |         | 1: INT2   | l      | Interrupt leve | el     | 1: INT1   | I      | nterrupt leve | I      |
|            |                     |         |           | INTA   | \LM4           |        |           | IN     | T3            |        |
|            | Interrupt           |         | IA4C      | IA4M2  | IA4M1          | IA4M0  | I3C       | I3M2   | I3M1          | I3M0   |
| INTE3ALM4  | enable<br>3 and     | 92H     | R         |        | R/W            |        | R         |        | R/W           |        |
|            | ALM4                |         | 0         | 0      | 0              | 0      | 0         | 0      | 0             | 0      |
|            |                     |         | 1:INTALM4 | l      | Interrupt leve | el     | 1: INT3   | I      | nterrupt leve | I      |
|            |                     |         |           | INTA   | ALM1           |        |           | INTA   | ALM0          |        |
|            | Interrupt           |         | IA1C      | IA1M2  | IA1M1          | IA1M0  | IA0C      | IA0M2  | IA0M1         | IA0M0  |
| INTEALM01  | enable              | 93H     | R         |        | R/W            |        | R         | R/W    |               |        |
|            | ALM0/1              |         | 0         | 0      | 0              | 0      | 0         | 0      | 0             | 0      |
|            |                     |         | 1:INTALM1 | l      | Interrupt leve | el     | 1:INTALM0 |        |               | I      |
|            |                     |         |           | INTA   | ALM3           |        |           | INTA   | LM2           |        |
|            | Interrupt           |         | IA3C      | IA3M2  | IA3M1          | IA3M0  | IA2C      | IA2M2  | IA2M1         | IA2M0  |
| INTEALM23  | enable              | 94H     | R         |        | R/W            |        | R         |        | R/W           |        |
|            | ALM2/3              |         | 0         | 0      | 0              | 0      | 0         | 0      | 0             | 0      |
|            |                     |         | 1:INTALM3 | I      | Interrupt leve | el     | 1:INTALM2 | I      | nterrupt leve | I      |
|            |                     |         |           | INTTA1 | (TMRA1)        |        |           | INTTA0 | (TMRA0)       |        |
|            | Interrupt<br>enable |         | ITA1C     | ITA1M2 | ITA1M1         | ITA1M0 | ITA0C     | ITA0M2 | ITA0M1        | ITA0M0 |
| INTETA01   | timer A             | 95H     | R         |        | R/W            |        | R         |        | R/W           |        |
|            | 1/0                 |         | 0         | 0      | 0              | 0      | 0         | 0      | 0             | 0      |
|            |                     |         | 1: INTTA1 | l      | Interrupt leve | el     | 1: INTTA0 | I      | nterrupt leve | l      |
|            |                     |         |           | INTTA3 | (TMRA5)        |        |           | INTTA2 | (TMRA4)       |        |
|            | Interrupt<br>enable |         | ITA3C     | ITA3M2 | ITA3M1         | ITA3M0 | ITA2C     | ITA2M2 | ITA2M1        | ITA2M0 |
| INTETA23   | timer A             | 96H     | R         |        | R/W            |        | R         |        | R/W           |        |
|            | 3/2                 |         | 0         | 0      | 0              | 0      | 0         | 0      | 0             | 0      |
|            |                     |         | 1: INTTA3 | ı      | Interrupt leve | el     | 1: INTTA2 | I      | nterrupt leve | l      |
|            |                     |         |           | INT    | KEY            |        |           | INT    | RTC           |        |
|            | Interrupt           |         | IKC       | IKM2   | IKM1           | IKM0   | IRC       | IRM2   | IRM1          | IRM0   |
| INTERTCKEY | enable<br>RTC and   | 97H     | R         |        | R/W            |        | R         |        | R/W           |        |
|            | KEY                 |         | 0         | 0      | 0              | 0      | 0         | 0      | 0             | 0      |
|            |                     |         | 1: INTKEY |        | Interrupt leve | el     | 1: INTRTC | I      | nterrupt leve | I      |

### Interrupt control (2/3)

| Symbol    | Name                | Address | 7          | 6       | 5              | 4       | 3          | 2       | 1               | 0       |
|-----------|---------------------|---------|------------|---------|----------------|---------|------------|---------|-----------------|---------|
|           |                     |         |            | INT     | TX0            |         |            | INT     | RX0             |         |
|           | Interrupt           |         | ITX0C      | ITX0M2  | ITX0M1         | ITX0M0  | IRX0C      | IRX0M2  | IRX0M1          | IRX0M0  |
| INTES0    | enable              | 98H     | R          |         | R/W            |         | R          |         | R/W             |         |
|           | serial 0            |         | 0          | 0       | 0              | 0       | 0          | 0       | 0               | 0       |
|           |                     |         | 1: INTTX0  | l       | nterrupt leve  | el      | 1: INTRX0  | I       | nterrupt leve   | l       |
|           |                     |         |            | INT     | TX1            |         |            | INT     | RX1             |         |
|           | Interrupt           |         | ITX1C      | ITX1M2  | ITX1M1         | ITX1M0  | IRX1C      | IRX1M2  | IRX1M1          | IRX1M0  |
| INTES1    | enable              | 99H     | R          |         | R/W            |         | R          |         | R/W             |         |
|           | serial 1            |         | 0          | 0       | 0              | 0       | 0          | 0       | 0               | 0       |
|           |                     |         | 1: INTTX1  | ı       | nterrupt leve  | el      | 1: INTRX1  | I       | nterrupt leve   | l       |
|           |                     |         |            | INT     | LCD            |         |            | INT     | SBI             |         |
|           | Interrupt           |         | ILCD2C     | ILCDM2  | ILCDM1         | ILCDM0  | ISBIC      | ISBIM2  | ISBIM1          | ISBIM0  |
| INTES2LCD | enable              | 9AH     | R          |         | R/W            |         | R          |         | R/W             |         |
|           | SBI/LCD             |         | 0          | 0       | 0              | 0       | 0          | 0       | 0               | 0       |
|           |                     |         | 1: INTLCD  |         | nterrupt leve  | el      | 1: INTSBI  | I       | Interrupt level |         |
|           |                     |         |            | INT     | TC1            |         |            | INT     | TC0             |         |
| INTETC01  | Interrupt<br>enable | 9BH     | ITC1C      | ITC1M2  | ITC1M1         | ITC1M0  | ITC0C      | ITC0M2  | ITC0M1          | ITC0M0  |
| INTETCOT  | TC0/1               | 9011    | R          |         | R/W            |         | R          |         | R/W             |         |
|           |                     |         | 0          | 0       | 0              | 0       | 0          | 0       | 0               | 0       |
|           |                     |         |            | INT     | TC3            |         |            | INT     | TC2             |         |
| INTETC23  | Interrupt<br>enable | 9CH     | ITC3C      | ITC3M2  | ITC3M1         | ITC3M0  | ITC2C      | ITC2M2  | ITC2M1          | ITC2M0  |
| INTLIGES  | TC2/3               | 3011    | R          |         | R/W            |         | R          |         | R/W             |         |
|           |                     |         | 0          | 0       | 0              | 0       | 0          | 0       | 0               | 0       |
|           |                     |         |            | IN      | ГР1            |         |            | INT     | P0              |         |
| INTEP01   | Interrupt<br>enable | 9DH     | IP1C       | IP1M2   | IP1M1          | IP1M0   | IP0C       | IP0M2   | IP0M1           | IP0M0   |
| INTLIGI   | PC0/1               | 3011    | R          |         | R/W            |         | R          |         | R/W             |         |
|           |                     |         | 0          | 0       | 0              | 0       | 0          | 0       | 0               | 0       |
|           |                     |         |            | INT     | TX2            |         |            | INT     | RX2             |         |
|           | Interrupt           |         | ITX2C      | ITX2M2  | ITX2M1         | ITX2M0  | IRX2C      | IRX2M2  | IRX2M1          | IRX2M0  |
| INTES3    | enable              | A0H     | R          |         | R/W            |         | R          |         | R/W             |         |
|           | serial 3            |         | 0          | 0       | 0              | 0       | 0          | 0       | 0               | 0       |
|           |                     |         | 1: INTTX2  | l       | nterrupt leve  | el      | 1: INTRX2  | Į       | nterrupt leve   | l       |
|           |                     |         |            | INT     | ГВ01           |         |            | INTT    | TB00            |         |
|           | Interrupt           |         | ITB01C     | ITB01M2 | ITB01M1        | ITB01M0 | ITB00C     | ITB00M2 | ITB00M1         | ITB00M0 |
| INTETB0   | enable              | A1H     | R          |         | R/W            |         | R          |         | R/W             |         |
|           | TMRB0               |         | 0          | 0       | 0              | 0       | 0          | 0       | 0               | 0       |
|           |                     |         | 1: INTTB01 |         | Interrupt leve | el      | 1: INTTB00 |         | nterrupt leve   | el      |

### Interrupt control (3/3)

| Symbol   |                     | Address   | 7                 | 6                 | 5            | 4              | 3            | 2             | 1             | 0                      |
|----------|---------------------|-----------|-------------------|-------------------|--------------|----------------|--------------|---------------|---------------|------------------------|
|          |                     | -         |                   |                   | DMA0V5       | DMA0V4         | DMA0V3       | DMA0V2        | DMA0V1        | DMA0V0                 |
| DMA0V    | DMA 0 request       | 80H       |                   |                   |              |                | R            | W             |               |                        |
| DIVIAUV  | vector              | ουп       |                   |                   | 0            | 0              | 0            | 0             | 0             | 0                      |
|          |                     |           |                   |                   |              |                | DMA0 st      | art vector    |               |                        |
|          |                     |           |                   |                   | DMA1V5       | DMA1V4         | DMA1V3       | DMA1V2        | DMA1V1        | DMA1V0                 |
| DMA1V    | DMA 1 request       | 81H       |                   |                   |              |                | R            | W             |               |                        |
| DIVIATV  | vector              | 0111      |                   |                   | 0            | 0              | 0            | 0             | 0             | 0                      |
|          |                     |           |                   |                   |              |                | DMA1 st      | art vector    |               |                        |
|          | D144.6              |           |                   |                   | DMA2V5       | DMA2V4         | DMA2V3       | DMA2V2        | DMA2V1        | DMA2V0                 |
| DMA2V    | DMA 2 request       | 82H       |                   |                   |              |                | R            | W             |               |                        |
| DIVIAZV  | vector              | OZII      |                   |                   | 0            | 0              | 0            | 0             | 0             | 0                      |
|          |                     |           |                   |                   |              |                | DMA2 st      | art vector    |               |                        |
|          | DMA 2               |           |                   |                   | DMA3V5       | DMA3V4         | DMA3V3       | DMA3V2        | DMA3V1        | DMA3V0                 |
| DMA3V    | DMA 3 request       | 83H       |                   |                   |              |                | R/           | W             |               |                        |
| Division | vector              | 0011      |                   |                   | 0            | 0              | 0            | 0             | 0             | 0                      |
|          |                     |           |                   |                   |              |                | DMA3 st      | art vector    |               |                        |
|          | lata mu sa t        | 88H       |                   |                   | CLRV5        | CLRV4          | CLRV3        | CLRV2         | CLRV1         | CLRV0                  |
| INTCLR   | Interrupt<br>clear  | (Prohibit |                   |                   |              | 1              |              | V             | 1             |                        |
|          | control             | RMW)      |                   |                   | 0            | 0              | 0            | 0             | 0             | 0                      |
|          |                     |           |                   |                   | Clea         | rs interrupt r | equest flag  | by writing to | DMA start v   | ector                  |
|          | DMA                 | 89H       |                   |                   |              |                | DMAR3        | DMAR2         | DMAR1         | DMAR0                  |
| DMAR     | software            | (Prohibit |                   |                   |              |                | R/W          | R/W           | R/W           | R/W                    |
|          | request<br>register | RMW)      |                   |                   |              |                | 0            | 0             | 0             | 0                      |
|          | register            |           |                   |                   |              |                |              |               | est in softwa |                        |
|          | DMA burst           |           |                   |                   |              |                | DMAB3        | DMAB2         | DMAB1         | DMAB0                  |
| DMAB     | request             | 8AH       |                   |                   |              |                | R/W          | R/W           | R/W           | R/W                    |
|          | register            |           |                   |                   |              |                | 0            | 0             | 0             | 0                      |
|          |                     |           |                   |                   |              |                |              |               | t on burst me |                        |
|          |                     |           | -                 | -                 | I3EDGE       | I2EDGE         | I1EDGE       | I0EDGE        | IOLE          | NMIREE                 |
|          |                     |           | W                 | W                 | W            | W              | W            | W             | W             | W                      |
|          | Interrupt           | 8CH       | 0                 | 0                 | 0            | 0              | 0            | 0             | 0             | 0                      |
| IIMC     | input mode control  | (Prohibit | Always write "0". | Always write "0". | INT3<br>edge | INT2<br>edge   | INT1<br>edge | INT0<br>edge  | INTO          | 1: Opera-<br>tion even |
|          | COTILIOI            | RMW)      | WIILE U.          | WIILE U.          | 0: Rising    | 0: Rising      | 0: Rising    | 0: Rising     | 0: Edge       | on NMI                 |
|          |                     |           |                   |                   | 1: Falling   | 1: Falling     | 1: Falling   | 1: Falling    | 1: Level      | rising                 |
|          |                     |           |                   |                   | alling       |                | alling       | alling        |               | edge                   |

## (4) Chip select/wait control (1/2)

| Symbol | Name               | Address           | 7          | 6       | 5           | 4     | 3                | 2                           | 1            | 0              |
|--------|--------------------|-------------------|------------|---------|-------------|-------|------------------|-----------------------------|--------------|----------------|
|        |                    |                   | B0E        |         | B0OM1       | В0ОМ0 | B0BUS            | B0W2                        | B0W1         | B0W0           |
|        |                    |                   | W          |         | W           | W     | W                | W                           | W            | W              |
|        | Block 0            | C0H               | 0          |         | 0           | 0     | 0                | 0                           | 0            | 0              |
| B0CS   | CS/WAIT control    | (Prohibit         | 0: Disable |         | 00: ROM/S   | RAM   | Data bus         | 000: 2 waits                | s 00: F      | Reserved       |
|        | register           | RMW)              | 1: Enable  |         | 01: ך       |       | width            | 001: 1 wait                 | 101:         | 3 waits        |
|        |                    |                   |            |         | 10: Res     | erved | 0: 16 bits       | 010: (1 + N                 | ) waits 110: | 4 waits        |
|        |                    |                   |            |         | 11: J       |       | 1: 8 bits        | 011: 0 waits                | s 111:       | 8 waits        |
|        |                    |                   | B1E        |         | B1OM1       | B1OM0 | B1BUS            | B1W2                        | B1W1         | B1W0           |
|        |                    |                   | W          |         | W           | W     | W                | W                           | W            | W              |
|        | Block 1<br>CS/WAIT | C1H               | 0          |         | 0           | 0     | 0                | 0                           | 0            | 0              |
| B1CS   | control            | (Prohibit         | 0: Disable |         | 00: ROM/S   | RAM   | Data bus         | 000: 2 waits                | s 100:       | Reserved       |
|        | register           | RMW)              | 1: Enable  |         | 01։ ๅ       |       | width            | 001: 1 wait                 | 101:         | 3 waits        |
|        |                    |                   |            |         | 10: Rese    | erved | 0: 16 bits       | 010: (1 + N                 | ) waits 110: | 4 waits        |
|        |                    |                   |            |         | 11: J       |       | 1: 8 bits        | 011: 0 waits                | s 111:       | 8 waits        |
|        |                    |                   | B2E        | B2M     | B2OM1       | B2OM0 | B2BUS            | B2W2                        | B2W1         | B2W0           |
|        | District           |                   | W          | W       | W           | W     | W                | W                           | W            | W              |
|        | Block 2<br>CS/WAIT | C2H               | 1          | 0       | 0           | 0     | 0                | 0                           | 0            | 0              |
| B2CS   | control            | (Prohibit         | 0: Disable | 0: 16 M | 00: ROM/S   | RAM   | Data bus         | 000: 2 waits                | s 100:       | Reserved       |
|        | register           | RMW)              | 1: Enable  | Area    | 01: ך       |       | width            | 001: 1 wait                 | 101:         | 3 waits        |
|        |                    |                   |            | 1: Area | 10: } Res   | erved | 0: 16 bits       | `                           | ) waits 110: | 4 waits        |
|        |                    |                   |            | set     | 11: J       | ı     | 1: 8 bits        | 011: 0 waits                | s 111:       | 8 waits        |
|        |                    |                   | B3E        |         | B3OM1       | B3OM0 | B3BUS            | B3W2                        | B3W1         | B3W0           |
|        | Diagle 0           |                   | W          |         | W           | W     | W                | W                           | W            | W              |
|        | Block 3<br>CS/WAIT | СЗН               | 0          |         | 0           | 0     | 0                | 0                           | 0            | 0              |
| B3CS   | control            | (Prohibit         | 0: Disable |         | 00: ROM/S   | RAM   | Data bus         | 000: 2 waits                |              | Reserved       |
|        | register           | RMW)              | 1: Enable  |         | 01: ر       |       | width            | 001: 1 wait                 |              | 3 waits        |
|        |                    |                   |            |         |             | erved | 0: 16 bits       | `                           | ) waits 110: |                |
|        |                    |                   |            |         | 11: J       |       | 1: 8 bits        | 011: 0 waits                |              | 8 waits        |
|        |                    |                   |            |         |             |       | BEXBUS           | BEXW2                       | BEXW1        | BEXW0          |
|        | External           |                   |            |         |             |       | W                | W                           | W            | W              |
| BEXCS  | CS/WAIT            | C7H               |            |         |             |       | 0                | 0                           | 0            | 0              |
| BEAGS  | control            | (Prohibit<br>RMW) |            |         |             |       | Data bus         | 000: 2 waits                |              | Reserved       |
|        | register           | TXIVIVV)          |            |         |             |       | width            | 001: 1 wait                 |              | 3 waits        |
|        |                    |                   |            |         |             |       | 0: 16 bits       | 010: (1 + N<br>011: 0 waits | ) waits 110: |                |
| -      |                    |                   | S23        | S22     | S21         | S20   | 1: 8 bits<br>S19 | S18                         | S17          | 8 waits<br>S16 |
|        | Memory             |                   | 323        | 322     | 321         | l     | W                | 310                         | 311          | 310            |
| MSAR0  | start<br>address   | C8H               | 1          | 1       | 1           | 1     | 1                | 1                           | 1            | 1              |
|        | register 0         |                   | ı          | '       |             |       | s A23 to A16     |                             | Ĺ            | Į.             |
|        |                    |                   | V20        | V19     | V18         | V17   | V16              | V15                         | V14 to V9    | V8             |
|        | Memory             |                   | V Z U      | VIS     | V 10        |       | W                | V IO                        | v 14 (U V9   | VO             |
| MAMR0  | address<br>mask    | C9H               | 1          | 1       | 1           | 1     | 1                | 1                           | 1            | 1              |
|        | register 0         |                   | ļ          |         | ) area size |       |                  | ress compari                |              | ı              |
|        |                    |                   | S23        | S22     | S21         | S20   | S19              | S18                         | S17          | S16            |
|        | Memory             |                   | 323        | 322     | 321         |       | W 519            | 310                         | 31/          | 310            |
| MSAR1  | start<br>address   | CAH               | 1          | 1       | 1           | 1     | 1                | 1                           | 1            | 1              |
|        | register 1         |                   | I          | 1       |             | •     | s A23 to A16     |                             | I            | 1              |
|        |                    |                   | \/04       | 1/20    |             | ı     |                  | 1                           | \/1E +~ \/0  | \/0            |
|        | Memory             |                   | V21        | V20     | V19         | V18   | V17              | V16                         | V15 to V9    | V8             |
| MAMR1  | address<br>mask    | СВН               | 4          | 4       | 4           |       | /W               | 4                           | 4            |                |
|        | register 1         |                   | 1          | 1       | 1           | 1     | 1                | 1                           | 1            |                |
|        | _                  |                   |            | CS      | 1 area size | 0: Er | nable to add     | ress compari                | son          |                |

## Chip select/wait control (2/2)

| Symbol    | Name       | Address | 7                                             | 6   | 5   | 4            | 3            | 2   | 1   | 0   |
|-----------|------------|---------|-----------------------------------------------|-----|-----|--------------|--------------|-----|-----|-----|
|           | Memory     |         | S23                                           | S22 | S21 | S20          | S19          | S18 | S17 | S16 |
| MSAR2     | start      | ССН     |                                               |     |     | R/           | W            |     | _   |     |
| WOARZ     | address    | COIT    | 1                                             | 1   | 1   | 1            | 1            | 1   | 1   | 1   |
|           | register 2 |         |                                               |     | ,   | Start addres | s A23 to A16 | 6   |     |     |
|           | Memory     |         | V22                                           | V21 | V20 | V19          | V18          | V17 | V16 | V15 |
| MAMR2     | address    | CDH     |                                               | R/W |     |              |              |     |     |     |
| IVIAIVINZ | mask       | CDIT    | 1                                             | 1   | 1   | 1            | 1            | 1   | 1   | 1   |
|           | register 2 |         | CS2 area size 0: Enable to address comparison |     |     |              |              |     |     |     |
|           | Memory     |         | S23                                           | S22 | S21 | S20          | S19          | S18 | S17 | S16 |
| MSAR3     | start      | CEH     |                                               |     |     | R/           | W            |     |     |     |
| WISANS    | address    | CLII    | 1                                             | 1   | 1   | 1            | 1            | 1   | 1   | 1   |
|           | register 3 |         |                                               |     | ,   | Start addres | s A23 to A16 | 6   |     |     |
|           | Memory     |         | V22                                           | V21 | V20 | V19          | V18          | V17 | V16 | V15 |
| MAMR3     | address    | CFH     |                                               |     |     | R/           | W            |     |     |     |
| INIVINIV  | mask       | OFT     | 1                                             | 1   | 1   | 1            | 1            | 1   | 1   | 1   |
|           | register 3 |         | CS3 area size 0: Enable to address comparison |     |     |              |              |     |     |     |

### (5) Clock gear (1/2)

| Symbol | Name                                     | Address | 7                                                                     | 6                                                                    | 5                                                                                                         | 4                                                                                                        | 3                                                            | 2                                                                                                                       | 1                                                                      | 0                                                     |
|--------|------------------------------------------|---------|-----------------------------------------------------------------------|----------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|--------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------|-------------------------------------------------------|
|        |                                          |         | XEN                                                                   | XTEN                                                                 | RXEN                                                                                                      | RXTEN                                                                                                    | RSYSCK                                                       | WUEF                                                                                                                    | PRCK1                                                                  | PRCK0                                                 |
|        |                                          |         |                                                                       |                                                                      |                                                                                                           | R/\                                                                                                      | N                                                            |                                                                                                                         |                                                                        |                                                       |
|        |                                          |         | 1                                                                     | 1                                                                    | 1                                                                                                         | 0                                                                                                        | 0                                                            | 0                                                                                                                       | 0                                                                      | 0                                                     |
| SYSCR0 | System<br>clock<br>control<br>register 0 | EOH     | High-<br>frequency<br>oscillator (fc)<br>0: Stopped<br>1: Oscillation | Low-<br>frequency<br>oscillator (fs)<br>0: Stopped<br>1: Oscillation | after release<br>of STOP<br>mode<br>0: Stopped                                                            | Low-<br>frequency<br>oscillator (fs)<br>after release<br>of STOP<br>mode<br>0: Stopped<br>1: Oscillation | mode<br>0: fc<br>1: fs                                       | Warm-up timer 0 write: Don't care 1 write: Start timer 0 read: End warm up 1 read: Not end warm up                      | Select presca<br>00: fFPH<br>01: Reserved<br>10: fc/16<br>11: Reserved |                                                       |
|        |                                          |         |                                                                       |                                                                      |                                                                                                           |                                                                                                          | SYSCK                                                        | GEAR2                                                                                                                   | GEAR1                                                                  | GEAR0                                                 |
|        |                                          |         |                                                                       |                                                                      |                                                                                                           |                                                                                                          |                                                              | R/                                                                                                                      |                                                                        |                                                       |
|        |                                          |         |                                                                       |                                                                      |                                                                                                           |                                                                                                          | 0                                                            | 1                                                                                                                       | 0                                                                      | 0                                                     |
| SYSCR1 | System<br>clock<br>control<br>register 1 | E1H     |                                                                       |                                                                      |                                                                                                           |                                                                                                          | System<br>clock<br>selection<br>0: fc<br>1: fs               | High-freque<br>selection (f<br>000: fc<br>001: fc/2<br>010: fc/4<br>011: fc/8<br>100: fc/16<br>101: (Rese<br>110: (Rese | rved)<br>rved)                                                         | lue                                                   |
|        |                                          |         | PSENV                                                                 |                                                                      | WUPTM1                                                                                                    | WUPTM0                                                                                                   | HALTM1                                                       | HALTM0                                                                                                                  | SELDRV                                                                 | DRVE                                                  |
|        |                                          |         | R/W                                                                   |                                                                      |                                                                                                           | i                                                                                                        | R/                                                           | 1                                                                                                                       | i                                                                      |                                                       |
| SYSCR2 | System<br>clock<br>control<br>register 2 | E2H     | 0 1: Disable 0: Power save mode enable                                |                                                                      | 1<br>Warm-up tir<br>00: Reserve<br>01: 2 <sup>8</sup> input<br>10: 2 <sup>14</sup><br>11: 2 <sup>16</sup> | ed                                                                                                       | 1<br>00: Reserve<br>01: STOP n<br>10: IDLE1 n<br>11: IDLE2 n | node<br>node                                                                                                            | O <drive> mode select 1: STOP 0: IDLE</drive>                          | 0<br>1: Drive the<br>pin in<br>STOP/<br>IDLE1<br>mode |

## Clock gear (2/2)

| Symbol | Name                         | Address | 7                                     | 6                                                           | 5                                                              | 4                                                             | 3                    | 2                                                | 1                                                          | 0                                                          |
|--------|------------------------------|---------|---------------------------------------|-------------------------------------------------------------|----------------------------------------------------------------|---------------------------------------------------------------|----------------------|--------------------------------------------------|------------------------------------------------------------|------------------------------------------------------------|
|        |                              |         | PROTECT                               | TA3LCE                                                      | AHOLD                                                          | TA3MLE                                                        | -                    | EXTIN                                            | DRVOSCH                                                    | DRVOSCL                                                    |
|        |                              |         | R                                     | R/W                                                         | R/W                                                            | R/W                                                           | R/W                  | R/W                                              | R/W                                                        | R/W                                                        |
|        |                              |         | 0                                     | 0                                                           | 0                                                              | 0                                                             | 0                    | 0                                                | 1                                                          | 1                                                          |
| EMCCR0 | EMC<br>control<br>register 0 | E3H     | Protection<br>flag<br>0: OFF<br>1: ON | LCDC<br>Source<br>clock<br>0: 32 kHz<br>1: TA3OUT           | Address<br>hold<br>0: Disable<br>1: Enable                     | Melody/<br>alarm<br>source<br>clock<br>0: 32 kHz<br>1: TA3OUT | Always<br>write "0". | 1: fc is<br>external<br>clock                    | fc oscillator<br>driver<br>ability<br>1: Normal<br>0: Weak | fs oscillator<br>driver<br>ability<br>1: Normal<br>0: Weak |
| EMCCR1 | EMC<br>control<br>register 1 | E4H     | C                                     | ontinuation v                                               | writes in 1ST                                                  | riting following -KEY: EMC                                    | CR1 = 5AH,           | EMCCR2 =                                         |                                                            |                                                            |
| EMCCR2 | EMC<br>control<br>register 2 | E5H     | )                                     |                                                             |                                                                |                                                               | ,                    |                                                  | <b>5</b> ,                                                 |                                                            |
|        |                              |         |                                       | ENFROM                                                      | ENDROM                                                         | ENPROM                                                        |                      | FFLAG                                            | DFLAG                                                      | PFLAG                                                      |
|        |                              |         |                                       | R/W                                                         | R/W                                                            | R/W                                                           |                      | R/W                                              | R/W                                                        | R/W                                                        |
|        |                              |         |                                       | 0                                                           | 0                                                              | 0                                                             |                      | 0                                                | 0                                                          | 0                                                          |
| EMCCR3 | EMC<br>control<br>register 3 | E6H     |                                       | CS1A<br>area<br>detect<br>enable<br>0: Disable<br>1: Enable | CS2B-2G<br>area<br>detect<br>Enable<br>0: Disable<br>1: Enable | CS2A<br>area<br>detect<br>enable<br>0: Disable<br>1: Enable   |                      | CS1A<br>write<br>operation<br>flag<br>When readi | 1: Writt                                                   | en                                                         |

### (6) DFM (Clock doubler)

| Symbol   | Name                  | Address |    | 7    |      | 6                | 5                    | 4                                     | 3             | 2         | 1   | 0   |
|----------|-----------------------|---------|----|------|------|------------------|----------------------|---------------------------------------|---------------|-----------|-----|-----|
|          |                       |         |    | ACT1 | А    | CT0              | DLUPFG               | DLUPTM                                |               |           |     |     |
|          |                       |         |    | R/W  | F    | R/W              | R                    | R/W                                   |               |           |     | /   |
|          | DEM                   |         |    | 0    |      | 0                | 0                    | 0                                     |               |           |     | /   |
| DFMCR0   | DFM<br>control        | E8H     |    | DFM  | LUP  | f <sub>FPH</sub> | Lock-up              | Lockup                                |               |           |     |     |
| Di Morto | register 0            | 2011    | 00 | STOP | STOP | fosch            | flag                 | time                                  |               |           |     |     |
|          |                       |         | 01 | RUN  | RUN  | fosch            |                      | 0: 2 <sup>12/</sup> fosch             |               |           |     |     |
|          |                       |         | 10 | RUN  | STOP | f <sub>DFM</sub> | 1: Do not<br>end LUP | 1: 2 <sup>10/</sup> f <sub>OSCH</sub> |               |           |     |     |
|          |                       |         | 11 | RUN  | STOP | fosch            | ena Lor              |                                       |               |           |     |     |
|          | DE14                  |         |    | D7   |      | D6               | D5                   | D4                                    | D3            | D2        | D1  | D0  |
| DFMCR1   | DFM<br>DFMCR1 control |         |    | R/W  | F    | R/W              | R/W                  | R/W                                   | R/W           | R/W       | R/W | R/W |
| DI WORT  | register 1            | Lon     |    | 0    |      | 0                | 0                    | 1                                     | 0             | 0         | 1   | 1   |
|          | -                     |         |    |      |      |                  | Write 0BI            | H before star                         | ting lockup o | peration. |     |     |

### (7) 8-bit timer

### (7-1) TMRA01

| Symbol  | Name            | Address   | 7              | 6      | 5                      | 4        | 3             | 2                      | 1             | 0       |  |
|---------|-----------------|-----------|----------------|--------|------------------------|----------|---------------|------------------------|---------------|---------|--|
|         |                 |           | TA0RDE         |        |                        |          | I2TA01        | TA01PRUN               | TA1RUN        | TA0RUN  |  |
|         |                 |           | R/W            |        |                        |          | R/W           | R/W                    | R/W           | R/W     |  |
|         | 8-bit timer     |           | 0              |        |                        |          | 0             | 0                      | 0             | 0       |  |
| TA01RUN | RUN             | 100H      | Double         |        |                        |          | IDLE2         | 8-bit timer ru         | un/stop contr | ol      |  |
|         |                 |           | buffer         |        |                        |          | 0: Stop       | 0: Stop and            | clear         |         |  |
|         |                 |           | 0: Disable     |        |                        |          | 1: Operate    | 1: Run (Cou            | ınt up)       |         |  |
|         |                 |           | 1: Enable      |        |                        |          |               |                        |               |         |  |
|         | 8-bit           | 102H      |                |        |                        |          | _             |                        |               |         |  |
| TA0REG  | timer           | (Prohibit |                |        |                        |          | W             |                        |               |         |  |
|         | register 0      | RMW)      |                |        |                        | Und      | defined       |                        |               |         |  |
|         | 8-bit           | 103H      |                |        |                        |          |               |                        |               |         |  |
| TA1REG  | timer           | (Prohibit | W<br>Undefined |        |                        |          |               |                        |               |         |  |
|         | register 1      | RMW)      |                |        |                        | Und      | defined       | TA1CLKO TA0CLK1 TA0CL  |               |         |  |
|         |                 |           | TA01M1         | TA01M0 | PWM01                  | PWM00    | TA1CLK1       | TA1CLK0 TA0CLK1 TA0C   |               |         |  |
|         | 8-bit           |           |                |        |                        | ı        | R/W           |                        |               |         |  |
|         | timer<br>source |           | 0              | 0      | 0                      | 0        | 0             | 0                      | 0             | 0       |  |
| TA01MOD | CLK and         | 104H      | 00: 8-bit tim  | ner    | 00: Reserv             |          | 00: TA0TRG    | }                      | 00: TA0IN p   | oin     |  |
|         | mode            |           | 01: 16-bit ti  | mer    | 01: 2 <sup>6</sup> PWI | √l cycle | 01: φT1       |                        | 01: φT1       |         |  |
|         | Register        |           | 10: 8-bit PF   | PG     | 10: 2 <sup>7</sup>     |          | 10: φT16      |                        | 10: φT4       |         |  |
|         |                 |           | 11: 8-bit PV   | VM     | 11: 2 <sup>8</sup>     |          | 11: φT256     |                        | 11: φT16      |         |  |
|         |                 |           |                |        |                        |          | TA1FFC1       | TA1FFC0                | TA1FFIE       | TA1FFIS |  |
|         | 8-bit           |           | R/W R/W        |        |                        |          |               | W                      |               |         |  |
|         | timer           | 105H      |                |        |                        |          | 1             | 1                      | 0             | 0       |  |
| TA1FFCR |                 | (Prohibit |                |        |                        |          | 00: Invert TA |                        |               |         |  |
|         | control         | RMW)      |                |        |                        |          | 01: Set TA1   | anahla                 |               |         |  |
|         | Register        |           |                |        |                        |          | 10: Clear TA  | TA1FF enable inversion |               |         |  |
|         |                 |           |                |        |                        |          | 11: Don't ca  | re                     |               |         |  |

### (7-2) TMRA23

| Symbol  | Name         | Address   | 7             | 6      | 5                      | 4       | 3            | 2                   | 1                                                                                                                                                                                                   | 0        |  |
|---------|--------------|-----------|---------------|--------|------------------------|---------|--------------|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|--|
|         |              |           | TA2RDE        |        |                        |         | I2TA23       | TA23PRUN            | TA3RUN                                                                                                                                                                                              | TA2RUN   |  |
|         |              |           | R/W           |        |                        |         | R/W          | R/W                 | R/W                                                                                                                                                                                                 | R/W      |  |
|         | 8-bit timer  |           | 0             |        |                        |         | 0            | 0                   | 0                                                                                                                                                                                                   | 0        |  |
| TA23RUN | RUN          | 108H      | Double        |        |                        |         | IDLE2        | 8-bit timer r       | 0 0 0  T-bit timer run/stop control Stop and clear Run (Count up)  TA3CLK0 TA2CLK1 TA2C  0 0 0  00: Reserved 01: \ph T1 10: \ph T4 11: \ph T16  TA3FFC0 TA3FFIE TA3I  R/W  1 0 0  FF 1: TA3FF 0: TM |          |  |
|         |              |           | buffer        |        |                        |         | 0: Stop      | 0: Stop and         | clear                                                                                                                                                                                               |          |  |
|         |              |           | 0: Disable    |        |                        |         | 1: Operate   | 1: Run (Co          | unt up)                                                                                                                                                                                             |          |  |
|         |              |           | 1: Enable     |        |                        |         |              |                     |                                                                                                                                                                                                     |          |  |
|         | 8-bit        | 10AH      |               |        |                        |         | _            |                     |                                                                                                                                                                                                     |          |  |
| TA2REG  | timer        | (Prohibit |               |        |                        |         | W            |                     |                                                                                                                                                                                                     |          |  |
|         | register 0   | RMW)      |               |        |                        | Und     | lefined      |                     |                                                                                                                                                                                                     |          |  |
|         | 8-bit        | 10BH      |               |        |                        |         |              |                     |                                                                                                                                                                                                     |          |  |
| TA3REG  | timer        | (Prohibit |               |        |                        |         | W            |                     |                                                                                                                                                                                                     |          |  |
|         | register 1   | RMW)      |               |        | 1                      |         | lefined      |                     |                                                                                                                                                                                                     |          |  |
|         |              |           | TA23M1        | TA23M0 | PWM21                  | PWM20   | TA3CLK1      | TA3CLK0             | TA2CLK1                                                                                                                                                                                             | TA2CLK0  |  |
|         | 8-bit        |           |               |        |                        | F       | R/W          |                     |                                                                                                                                                                                                     |          |  |
|         | timer        |           | 0             | 0      | 0                      | 0       | 0            | 0                   | 0                                                                                                                                                                                                   | 0        |  |
| TA23MOD | source       | 10CH      | 00: 8-bit tim | ner    | 00: Reserv             |         | 00: TA2TR0   | <del>}</del>        |                                                                                                                                                                                                     | ed       |  |
|         | CLK and mode |           | 01: 16-bit ti |        | 01: 2 <sup>6</sup> PWN | 1 cycle | 01: φT1      |                     | ·                                                                                                                                                                                                   |          |  |
|         | mode         |           | 10: 8-bit PF  | -      | 10: 2 <sup>7</sup>     |         | 10: φT16     |                     | -                                                                                                                                                                                                   |          |  |
|         |              |           | 11: 8-bit PV  | VM     | 11: 2 <sup>8</sup>     |         | 11: φT256    | 1                   | ·                                                                                                                                                                                                   |          |  |
|         |              |           |               |        |                        |         | TA3FFC1      |                     |                                                                                                                                                                                                     | TA3FFIS  |  |
|         | 8-bit        |           |               |        |                        |         |              | <u> </u>            |                                                                                                                                                                                                     |          |  |
| TAGEEGE | timer        | 10DH      |               |        |                        |         | 1            | -                   |                                                                                                                                                                                                     | 0        |  |
| TA3FFCR | flip-flop    | (Prohibit |               |        |                        |         | 00: Invert T | _                   | _                                                                                                                                                                                                   | 0: TMRA2 |  |
|         | control      | RMW)      |               |        |                        |         | 01: Set TA3  | 1. 11/11/14         |                                                                                                                                                                                                     |          |  |
|         |              |           |               |        |                        |         | 10: Clear TA | A3FF enable inversi |                                                                                                                                                                                                     |          |  |
|         |              |           |               |        |                        |         | 11: Don't ca | re                  |                                                                                                                                                                                                     |          |  |

**TOSHIBA** 

### (8) UART/serial channel (1/3)

## (8-1) UART/SIO channel 0

| Symbol  | Name             | Address   | 7                   | 6            | 5                  | 4            | 3               | 2            | 1                             | 0                        |
|---------|------------------|-----------|---------------------|--------------|--------------------|--------------|-----------------|--------------|-------------------------------|--------------------------|
|         | Serial           | 200H      | RB7/TB7             | RB6/TB6      | RB5/TB5            | RB4/TB4      | RB3/TB3         | RB2/TB2      | RB1/TB1                       | RB0/TB0                  |
| SC0BUF  | channel 0        | (Prohibit |                     |              | R (F               | Receiving)/W | / (Transmiss    | ion)         |                               |                          |
|         | buffer           | RMW)      |                     |              |                    | Unde         | fined           |              |                               |                          |
|         |                  |           | RB8                 | EVEN         | PE                 | OERR         | PERR            | FERR         | SCLKS                         | IOC                      |
|         | Serial           |           | R                   | R/           |                    | R (Clea      | red to 0 by r   | eading)      |                               | /W                       |
| SC0CR   | channel 0        | 201H      | Undefined           | 0            | 0                  | 0            | 0               | 0            | 0                             | 0                        |
|         | control          |           | Receiving data bit8 | Parity       | 1: Parity enable   |              | 1: Error        | i            | 0:SCLK0↑                      | 1: Input<br>SCLK0        |
|         |                  |           | uala bilo           | 0: Odd       | enable             | Overrun      | Parity          | Framing      | 1:SCLK0↓                      | pin                      |
|         |                  |           | TDO                 | 1: Even      | DVE                | WU           | CM4             | CMO          | 004                           | ·                        |
|         |                  |           | TB8                 | CTSE         | RXE                | _            | SM1<br>W        | SM0          | SC1                           | SC0                      |
|         |                  |           | 0                   | 0            | 0                  | 0            | 0               | 0            | 0                             | 0                        |
|         | Serial           |           | Transmission        |              | 1: Receive         | 1: Wakeup    | 00: I/O Inte    | _            | 00: TA0TR                     |                          |
| SC0MOD0 | channel 0        | 202H      | data bit8           | enable       | enable             | enable       | 01: UART 7      |              | 01: Baud ra                   | _                        |
|         | mode0            |           |                     |              |                    |              | 10: UART 8 bits |              | genera                        |                          |
|         |                  |           |                     |              |                    |              | 11: UART 9      | 9 bits       | 10: Interna                   | l clock f <sub>SYS</sub> |
|         |                  |           |                     |              |                    |              |                 |              | 11: Externa                   |                          |
|         |                  |           |                     | DDOADDE      | DD001/4            | DD 001/0     | BB000           | DD000        | SCLK0                         |                          |
|         |                  |           | _                   | BR0ADDE      | BR0CK1             | BR0CK0       | BR0S3<br>W      | BR0S2        | BR0S1                         | BR0S0                    |
|         |                  |           | 0                   | 0            |                    | )<br>)       | 0               | 0            | 0                             | 0                        |
| BR0CR   | Baud rate        | 203H      | Always              | 1: (16-K)/16 |                    | J            |                 |              | ded frequen                   | _                        |
|         | control          |           | write "0".          | divided      | 00: φ10<br>01: φT2 |              | Octui           | -            | o F)                          | by IV                    |
|         |                  |           |                     | enable       | 10: φT8            |              |                 | (0.          | 0.,                           |                          |
|         |                  |           |                     |              | 11: φT32           |              |                 |              |                               |                          |
|         |                  |           |                     |              |                    |              | BR0K3           | BR0K2        | BR0K1                         | BR0K0                    |
|         | Serial channel 0 |           |                     |              |                    |              |                 | R            | W                             | •                        |
| BR0ADD  | K setting        | 204H      |                     |              |                    |              | 0               | 0            | 0                             | 0                        |
|         | register         |           |                     |              |                    |              |                 |              | cy divisor "K<br>= (16 – K)/1 |                          |
|         |                  |           | 1280                | FDPX0        |                    |              | (L              | Nivided by N | - (10 - K)/1                  | 0)                       |
|         |                  |           | R/W                 | R/W          | //                 |              |                 |              |                               |                          |
|         | Serial           |           | 0                   | 0            |                    |              |                 |              |                               |                          |
| SC0MOD1 | channel 0        | 205H      | IDLE2               | Duplex       |                    |              |                 |              |                               |                          |
|         | mode1            |           | 0: Stop             | 0: Half      |                    |              |                 |              |                               |                          |
|         |                  |           | 1: Operate          | 1: Full      |                    |              |                 |              |                               |                          |

## (8-2) IrDA

| Symbol | Name     | Address | 7            | 6          | 5            | 4          | 3              | 2            | 1             | 0            |
|--------|----------|---------|--------------|------------|--------------|------------|----------------|--------------|---------------|--------------|
|        |          |         | PLSEL        | RXSEL      | TXEN         | RXEN       | SIRWD3         | SIRWD2       | SIRWD1        | SIRWD0       |
|        |          |         | R/W          | R/W        | R/W          | R/W        |                | R            | W             |              |
|        | IrDA     |         | 0            | 0          | 0            | 0          | 0              | 0            | 0             | 0            |
| SIRCR  | control  | 207H    | Transmission | Receiving  | Transmission | Receiving  | Set the effect | tive SIRRxD  | pulse width   |              |
|        | register |         | pulse width  | data       | 0: Disable   | 0: Disable | Pulse width    | more than 2x | x × (Set valu | e + 1) + 100 |
|        | register |         |              | 0: H pulse | 1: Enable    | 1: Enable  | ns             |              |               |              |
|        |          |         | 1: 1/16      | 1: L pulse |              |            | Possible: 1 t  | o 14         |               |              |
|        |          |         |              |            |              |            | Not possible   | : 0, 15      |               |              |

### UART/serial channel (2/3)

### (8-3) UART/SIO channel 1

| Symbol  | Name               | Address   | 7                    | 6                       | 5          | 4            | 3                                                          | 2       | 1               | 0           |
|---------|--------------------|-----------|----------------------|-------------------------|------------|--------------|------------------------------------------------------------|---------|-----------------|-------------|
|         | Serial             | 208H      | RB7/TB7              | RB6/TB6                 | RB5/TB5    | RB4/TB4      | RB3/TB3                                                    | RB2/TB2 | RB1/TB1         | RB0/TB0     |
| SC1BUF  | channel 1          | (Prohibit |                      |                         | R (F       | Receiving)/W | / (Transmiss                                               | ion)    |                 |             |
|         | buffer             | RMW)      |                      |                         |            | Unde         | efined                                                     |         |                 |             |
|         |                    |           | RB8                  | EVEN                    | PE         | OERR         | PERR                                                       | FERR    | SCLKS           | IOC         |
|         | Serial             |           | R                    | R/                      | W          | R (Clea      | red to 0 by r                                              | eading) | R/              | W           |
| SC1CR   | channel 1          | 209H      | Undefined            | 0                       | 0          | 0            | 0                                                          | 0       | 0               | 0           |
| OOTOR   | control            | 20011     |                      | Parity                  | 1: Parity  |              | 1: Error                                                   |         | 0: SCLK1↑       | 1: Input    |
|         | CONTROL            |           | data bit8            | 0: Odd                  | enable     | Overrun      | Parity                                                     | Framing | 1: SCLK1↓       | SCLK1 pin   |
|         |                    |           |                      | 1: Even                 |            |              |                                                            |         |                 |             |
|         |                    |           | TB8                  | CTSE                    | RXE        | WU           | SM1                                                        | SM0     | SC1             | SC0         |
|         |                    |           |                      |                         |            | R            | W                                                          |         |                 |             |
|         | Serial             |           | 0                    | 0                       | 0          | 0            | 0                                                          | 0       | 0               | 0           |
| SC1MOD0 | channel 1          | 20AH      | Transmission         |                         | 1: Receive | 1: Wakeup    | 00: I/O Interf                                             | ace     | 00: TA0TRG      |             |
|         | mode               |           | data bit8            | enable                  | enable     | enable       | 01: UART 7                                                 |         | 01: Baud rate   | ŭ           |
|         |                    |           |                      |                         |            |              | 10: UART 8                                                 |         | 10: Internal of | 0.0         |
|         |                    |           |                      |                         |            |              | 11: UART 9                                                 |         |                 | clock SCLK1 |
|         |                    |           | =                    | BR1ADDE                 | BR1CK1     | BR1CK0       | BR1S3                                                      | BR1S2   | BR1S1           | BR1S0       |
|         |                    |           |                      | i                       | i          | 1            | W                                                          | i       | i               | 1           |
| BR1CR   | Baud rate          | 20BH      | 0                    | 0                       | 0          | 0            | 0                                                          | 0       | 0               | 0           |
| BRICK   | control            | 20BH      | Always<br>write "0". | 1: (16-K)/16<br>divided |            |              | Settin                                                     | Ü       | ded frequen     | cy "N"      |
|         |                    |           | write 0.             | enable                  | 01: φT2    |              |                                                            | (0 t    | o F)            |             |
|         |                    |           |                      | 0114210                 | 10: φT8    |              |                                                            |         |                 |             |
|         |                    |           |                      |                         | 11: φT32   |              | 554140                                                     | 55440   | 55444           | DD4140      |
|         | Serial             |           |                      |                         |            |              | BR1K3                                                      | BR1K2   | BR1K1           | BR1K0       |
| BR1ADD  | channel 1          | 20CH      |                      |                         |            |              | 0                                                          | ·       | W               | 0           |
| DICIADO | K setting          | 20011     |                      |                         |            |              | 0                                                          | 0       | 0               | 0           |
|         | register           |           |                      |                         |            |              | Sets frequency divisor "K"<br>(Divided by N = (16 – K)/16) |         |                 |             |
|         |                    |           | 12S1                 | FDPX1                   |            |              |                                                            |         |                 |             |
|         | 0 1                |           | R/W                  | R/W                     |            |              |                                                            |         |                 |             |
| CC4MOD4 | Serial             | 20011     | 0                    | 0                       |            |              |                                                            |         |                 |             |
| SC1MOD1 | channel 1<br>mode1 | 20DH      | IDLE2                | Duplex                  |            |              |                                                            |         |                 |             |
|         | moder              |           | 0: Stop              | 0: Half                 |            |              |                                                            |         |                 |             |
|         |                    |           | 1: Operate           | 1: Full                 |            |              |                                                            |         |                 |             |

TOSHIBA TMP91C820A

### UART/serial channel (3/3)

### (8-4) UART/SIO channel 2

| Symbol   | Name             | Address   | 7            | 6                 | 5          | 4            | 3             | 2             | 1                             | 0          |
|----------|------------------|-----------|--------------|-------------------|------------|--------------|---------------|---------------|-------------------------------|------------|
|          | Serial           | 210H      | RB7/TB7      | RB6/TB6           | RB5/TB5    | RB4/TB4      | RB3/TB3       | RB2/TB2       | RB1/TB1                       | RB0/TB0    |
| SC2BUF   | channel 2        | (Prohibit |              |                   | R (F       | Receiving)/W | / (Transmiss  | ion)          |                               |            |
|          | buffer           | RMW)      |              |                   |            | Unde         | efined        |               |                               |            |
|          |                  |           | RB8          | EVEN              | PE         | OERR         | PERR          | FERR          | -                             | -          |
|          | Serial           |           | R            | R/                | W          | R (Clea      | red to 0 by r | eading)       | R/                            | W          |
| SC2CR    | channel 2        | 211H      | Undefined    | 0                 | 0          | 0            | 0             | 0             | 0                             | 0          |
| 302010   | control          | 21111     | Receiving    | Parity            | 1: Parity  |              | 1: Error      |               | Always                        | Always     |
|          | CONTROL          |           | data bit8    | 0: Odd<br>1: Even | enable     | Overrun      | Parity        | Framing       | write "0".                    | write "0". |
|          |                  |           | TDO          | i. Even           | DVE        | \A/I I       | CN4           | CMO           | 004                           | 000        |
|          |                  |           | TB8          | _                 | RXE        | WU           | SM1<br>/W     | SM0           | SC1                           | SC0        |
|          | Serial           |           | 0            | 0                 | 0          | 0            | 0             | 0             | 0                             | 0          |
| SC2MOD0  |                  | 212H      | Transmission |                   | 1: Receive | 1: Wakeup    | 00: Reserve   |               | 00: TA0TRG                    |            |
| OOZINODO | mode             | 21211     | data bit8    | write "0".        | enable     | enable       | 01: UART 7    |               | 01: Baud rat                  |            |
|          |                  |           |              |                   |            |              | 10: UART 8    |               | clock f <sub>SYS</sub>        |            |
|          |                  |           |              |                   |            |              | 11: UART 9    |               | 11: Reserve                   |            |
|          |                  |           | _            | BR2ADDE           | BR2CK1     | BR2CK0       | BR2S3         | BR2S2         | BR2S1                         | BR2S0      |
|          |                  |           |              |                   | 21120111   |              | W             | 2202          | 220.                          | 2.1.200    |
|          |                  |           | 0            | 0                 | 0          | 0            | 0             | 0             | 0                             | 0          |
| BR2CR    | Baud rate        | 213H      | Always       | 1: (16-K)/16      | 00: φΤ0    | l            | <b>.</b>      | a of the divi | ded frequenc                  | cv "N"     |
|          | control          |           | write "0".   | divided           | 01: φT2    |              |               | •             | o F)                          | ,          |
|          |                  |           |              | enable            | 10: φT8    |              |               | `             | ,                             |            |
|          |                  |           |              |                   | 11: φT32   |              |               |               |                               |            |
|          |                  |           |              |                   |            |              | BR1K3         | BR1K2         | BR1K1                         | BR1K0      |
|          | Serial channel 2 |           |              |                   |            |              |               | R             | W                             |            |
| BR2ADD   | K setting        | 214H      |              |                   |            |              | 0             | 0             | 0                             | 0          |
|          | register         |           |              |                   |            |              |               |               | cy divisor "K<br>= (16 – K)/1 |            |
|          |                  |           | 12\$2        | FDPX2             |            |              |               |               |                               |            |
|          |                  |           | R/W          | R/W               |            |              |               |               |                               |            |
| 00014004 | Serial           | 0.451.1   | 0            | 0                 |            |              |               |               |                               |            |
| SC2MOD1  | channel 2        | 215H      | IDLE2        | Duplex            |            |              |               |               |                               |            |
|          | mode1            |           | 0: Stop      | 0: Half           |            |              |               |               |                               |            |
|          |                  |           | 1: Operate   | 1: Full           |            |              |               |               |                               |            |

### (9) I<sup>2</sup>C bus/serial interface (1/2)

| Symbol        | Name                 | Address                       | 7         | 6                   | 5                      | 4                   | 3                                          | 2                        | 1                              | 0                       |
|---------------|----------------------|-------------------------------|-----------|---------------------|------------------------|---------------------|--------------------------------------------|--------------------------|--------------------------------|-------------------------|
|               |                      |                               | BC2       | BC1                 | BC0                    | ACK                 |                                            | SCK2                     | SCK1                           | SCK0<br>/SWRMON         |
|               |                      | 240H<br>(I <sup>2</sup> C bus |           | W                   |                        | R/W                 |                                            | W                        | W                              | R/W                     |
|               |                      | mode)                         | 0         | 0                   | 0                      | 0                   |                                            | 0                        | 0                              | 0/1                     |
|               |                      | (Prohibit                     |           | transfer bits       |                        | Acknowledge mode    |                                            | _                        | ne devisor val                 |                         |
|               |                      | RMW)                          |           |                     | 0: 2<br>1: 5           | 0: Disable          |                                            |                          | 01: 6                          |                         |
|               | Serial bus interface |                               |           | 100: 4 10<br>111: 7 | 1. 5                   | 1: Enable           |                                            |                          | I1: (Reserved                  |                         |
| SBI0CR1       | control              |                               | SIOS      | SIOINH              | SIOM1                  | SIOM0               |                                            | SCK2                     | SCK1                           | SCK0                    |
|               | register 1           |                               | W         | W                   | W                      | W                   |                                            | W                        | W                              | W                       |
|               |                      | 240H                          | 0         | 0                   | 0                      | 0                   |                                            | 0                        | 0                              | 0                       |
|               |                      | (SIO<br>mode)                 | Transfer  | Transfer            | Transfer m             | ode                 |                                            | Setting for th           | ne divisor valu                | e n                     |
|               |                      | (Prohibit                     | 0: Stop   | 0: Continue         | 00: 8-bit tra          | insmit mode         |                                            | 000: 4 00                | 01: 5 010: 0                   |                         |
|               |                      | `RMW)                         | 1: Start  | 1: Abort            | 10: 8-bit tra          |                     |                                            |                          | 00: 8 101: 9                   | 9                       |
|               |                      |                               |           |                     | receive                | mode<br>ceived mode |                                            | 110: 10 11               | 11: SCK pin                    |                         |
|               | SBI                  | 241H                          | DB7       | DB6                 | DB5                    | DB4                 | DB3                                        | DB2                      | DB1                            | DB0                     |
| SBI0DBR       | buffer               | (Prohibit                     | DB1       | DB0                 |                        | R (Receiving)/      |                                            |                          | DD1                            | DB0                     |
|               | register             | RMW)                          |           |                     | <u> </u>               |                     | defined                                    | 551011)                  |                                |                         |
|               |                      |                               | SA6       | SA5                 | SA4                    | SA3                 | SA2                                        | SA1                      | SA0                            | ALS                     |
|               |                      |                               | W         | W                   | W                      | W                   | W                                          | W                        | W                              | W                       |
|               | I2CBUS               | 242H                          | 0         | 0                   | 0                      | 0                   | 0                                          | 0                        | 0                              | 0                       |
| I2C0AR        | address<br>register  | (Prohibit<br>RMW)             |           |                     | c.                     | etting slave ac     | ddrooo                                     |                          |                                | Address recognition     |
|               |                      |                               |           |                     | 36                     | stillig slave at    | uiess                                      |                          |                                | 0: Enable<br>1: Disable |
|               |                      |                               | MST       | TRX                 | BB                     | PIN                 | AL/SBIM1                                   | AAS/SBIM0                | AD0/<br>SWRST                  | LRB/<br>SWRST0          |
|               |                      |                               | R/W       | R/W                 | R/W                    | R/W                 | R/W                                        | R/W                      | R/W                            | R/W                     |
| When          | Serial bus           |                               | 0         | 0                   | 0                      | 1                   | 0                                          | 0                        | 0                              | 0                       |
| read          | interface<br>status  |                               | 0: Slave  | 0: Receiver         |                        | INTSBI              | Arbitration                                | Slave                    | GENERAL                        | Lost                    |
| SBI0SR        | register             | 243H                          | 1: Master | 1: Transmit         |                        | request<br>monitor  | lost<br>detection                          | address<br>match         | CALL<br>detection              | receive bit monitor     |
|               |                      | (I <sup>2</sup> C bus         |           |                     | 0: Free<br>1: Busy     | 0: Request          | monitor                                    | detection                | monitor                        | 0: 0                    |
|               |                      | mode)                         |           |                     | i. busy                | 1: Cancel           | 1: Detect                                  | monitor                  | 1: Detect                      | 1: 1                    |
|               |                      | (Prohibit                     |           |                     |                        |                     |                                            | 1: Detect                |                                |                         |
|               |                      | RMW)                          |           |                     | Start/stop             |                     | Serial bus int                             | erface                   | Software rese                  | -                       |
| 140           | Serial bus           |                               |           |                     | condition              |                     | operating mo                               |                          | write "10" and                 |                         |
| When<br>write | interface            |                               |           |                     | generation<br>0: Start |                     | 00: Port mod                               |                          | internal reset s<br>generated. | signal is               |
| SBI0CR2       | control              |                               |           |                     | condition              |                     | 01: SIO mode<br>10: I <sup>2</sup> C bus m |                          |                                |                         |
|               | register 2           |                               |           |                     | 1: Stop                |                     | 11: (Reserve                               |                          |                                |                         |
|               |                      |                               |           |                     | condition              |                     | (                                          | <u>.</u>                 |                                | ı                       |
|               |                      |                               |           |                     |                        |                     | SIOF/SBIM1                                 | SEF/SBIM2                | -                              | =                       |
|               |                      |                               |           |                     |                        |                     | R                                          | R                        | W                              | W                       |
| When          | Serial bus           |                               |           |                     |                        |                     | 0                                          | 0                        | 0                              | 0                       |
| read          | interface<br>status  |                               |           |                     |                        |                     | Transfer status                            | Shift operation          |                                |                         |
| SBI0SR        | register             | 243H                          |           |                     |                        |                     | monitor                                    | status monitor           |                                |                         |
|               |                      | (SIO                          |           |                     |                        |                     | 0: Stopped 1: Terminated                   | 0: Stopped 1: Terminated |                                |                         |
|               |                      | mode)                         |           |                     |                        |                     | in process                                 | in process               |                                |                         |
|               |                      | (Prohibit<br>RMW)             |           |                     |                        |                     | Serial bus int                             | !                        | Always                         | Always                  |
|               | Serial bus           | TXIVIVV)                      |           |                     |                        |                     | operating mo                               |                          | write "0".                     | write "0".              |
| When<br>write | interface            |                               |           |                     |                        |                     | 00: Port mod                               | е                        |                                |                         |
| SBI0CR2       | control              |                               |           |                     |                        |                     | 01: SIO mode                               |                          |                                |                         |
|               | register 2           |                               |           |                     |                        |                     | 10: I <sup>2</sup> C bus m                 |                          |                                |                         |
|               |                      |                               |           |                     |                        |                     | 11: (Reserve                               | d)                       |                                |                         |

I<sup>2</sup>C bus/serial interface (2/2)

| Symbol  | Name                    | Address           | 7                            | 6                    | 5 | 4 | 3 | 2 | 1 | 0 |
|---------|-------------------------|-------------------|------------------------------|----------------------|---|---|---|---|---|---|
|         |                         |                   | -                            | I2SBI0               |   |   |   |   |   |   |
|         | Serial bus              | 244H              | W                            | R/W                  |   |   |   |   |   |   |
| SBI0BR0 | interface               | (Prohibit         | 0                            | 0                    |   |   |   |   |   |   |
|         | baud rate               | RMW)              | Always                       | IDLE2                |   |   |   |   |   |   |
|         | register 0              | ''''''            |                              | 0: Abort             |   |   |   |   |   |   |
|         |                         |                   |                              | 1: Operate           |   |   |   |   |   |   |
|         |                         |                   | P4EN                         |                      |   |   |   |   |   |   |
|         | 0                       |                   | W                            | W                    |   |   |   |   |   |   |
|         | Serial bus interface    | 245H              | 0                            | 0                    |   |   |   |   |   |   |
| SBI0BR1 | baud rate<br>register 1 | (Prohibit<br>RMW) | Clock<br>control<br>0: Abort | Always<br>write "0". |   |   |   |   |   |   |
|         |                         |                   | 1: Operate                   |                      |   |   |   |   |   |   |

### (10) AD converter

| ADMODU AD mode register 0 2B0H                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Symbol    | Name                 | Address       | 7      | 6        | 5     | 4     | 3               | 2                                                                                                     | 1                                                                                                                         | 0                     |  |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|----------------------|---------------|--------|----------|-------|-------|-----------------|-------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------|-----------------------|--|--|
| ADMODD AD mode register of egister of 2B0H and provided register of 15 for register of 15 for register of 15 for register of 15 for register regis  |           |                      |               | EOCF   | ADBF     | -     | _     | ITM0            | REPEAT                                                                                                | SCAN                                                                                                                      | ADS                   |  |  |
| ADMODD   register 0   280H     1: Busy                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |           |                      |               | F      | ₹        | R/W   | R/W   | R/W             | R/W                                                                                                   | R/W                                                                                                                       | R/W                   |  |  |
| Tegister   1   1   1   1   1   1   1   1   1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | ADMOD0    |                      | 2B0H          | 0      | 0        | 0     | 0     | 0               | 0                                                                                                     | 0                                                                                                                         | 0                     |  |  |
| ADMODI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |           | register 0           |               | 1: End | 1: Busy  |       |       | in repeat       | 1: Repeat                                                                                             | 1: Scan                                                                                                                   | 1: Start              |  |  |
| ADMODI AD mode register 1 AD mode register 1 AD mode register 1 AD mode register 1 AD result register 0/4 high  AD result register 1/5 low  AD result register 1/5 low  AD an                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |           |                      |               | VREFON | I2AD     |       |       | ADTRGE          | ADCH2                                                                                                 | ADCH1                                                                                                                     | ADCH0                 |  |  |
| ADMOD1 AD mode register 1 AD mode register 2 AD mo  |           |                      |               | R/W    | R/W      |       |       | R/W             |                                                                                                       | R/W                                                                                                                       |                       |  |  |
| AD MODI President AD mode register 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |           |                      |               | 0      | 0        |       |       | 0               | 0                                                                                                     | 0                                                                                                                         | 0                     |  |  |
| ADREG04L register 0/4 low 2A0H                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | ADMOD1    |                      | 2B1H          |        | 0: Abort |       |       | for<br>external | 000: AN0 AN<br>001: AN1 AN<br>010: AN2 AN<br>011: AN3 AN<br>100: AN4 AN<br>101: AN5 AN<br>110: AN6 AN | $0 \rightarrow AN1$ $0 \rightarrow AN1 \rightarrow A$ $0 \rightarrow AN1 \rightarrow A$ $4 \rightarrow AN5 \rightarrow A$ | $NN2 \rightarrow AN3$ |  |  |
| ADREG04L register 0/4 low Part 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |           | AD result            |               | ADR01  | ADR00    |       |       |                 |                                                                                                       |                                                                                                                           | ADR0RF                |  |  |
| ADREG04H register register 1/5 low  AD result register 2/6 low  AD result register 2/6 low  AD result register 1/5 low  AD result register 2/6 low  AD Result Result register 2/6 low  AD Result Result register 2/6 low  AD Result Resu  | ADREG04L  |                      | 2A0H          | F      | 3        |       |       |                 |                                                                                                       |                                                                                                                           | R                     |  |  |
| ADREG04H register 0/4 high 2A1H                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |           | 0/4 low              |               | Unde   | efined   |       |       |                 |                                                                                                       |                                                                                                                           | 0                     |  |  |
| ADREG15L   ADR result register 1/5 low   ADR19   ADR18   ADR17   ADR16   ADR15   ADR14   ADR13   ADR12                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |           | AD result            |               | ADR09  | ADR08    | ADR07 | ADR06 | ADR05           | ADR04                                                                                                 | ADR03                                                                                                                     | ADR02                 |  |  |
| ADREG15L register 1/5 low 2ADR19 ADR18 ADR17 ADR16 ADR15 ADR14 ADR13 ADR12  ADREG15H register 1/5 high ADR20 ADR26 ADR25 ADR24 ADR23 ADR22  ADREG26H register 2/6 high ADR29 ADR28 ADR27 ADR26 ADR25 ADR24 ADR23 ADR22  ADREG37H register 2/6 high ADR31 ADR30 ADR36 ADR35 ADR34 ADR37 ADR36 ADR35 ADR34 ADR33 ADR32  ADREG37H register 2/6 high ADR20 ADR38 ADR37 ADR36 ADR35 ADR34 ADR33 ADR32  ADREG37H Register 2/6 high ADR39 ADR38 ADR37 ADR36 ADR35 ADR34 ADR33 ADR32  ADREG37H Register 2/6 high ADR39 ADR38 ADR37 ADR36 ADR35 ADR34 ADR33 ADR32  ADREG37H Register 2/6 high ADR39 ADR38 ADR37 ADR36 ADR35 ADR34 ADR33 ADR32                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | ADREG04H  |                      | 2A1H          |        |          |       |       |                 |                                                                                                       |                                                                                                                           |                       |  |  |
| ADREG15L register 1/5 low 2A2H R Undefined 0  AD result register 1/5 high 2A3H 2A3H 2A3H 2A3H 2A3H 2A3H 2A3H 2A3H                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |           | _                    |               | 10044  | 10010    |       | Unde  | etined          |                                                                                                       |                                                                                                                           | 400405                |  |  |
| AD result register 2/6 high   AD result register 3/7 low   AD result ADREG37H register 3/7 low   AD result Register R    | ADDEC451  |                      | 24211         |        |          |       |       |                 |                                                                                                       |                                                                                                                           |                       |  |  |
| AD result register 1/5 high  AD result register 2/6 low  AD result register 2/6 high  AD result register 3/7 low  AD result register 3/7 low  AD result register 2/6 high  AD result register 2/6 high  AD result register 2/6 high  AD result register 3/7 low  AD result R  AD resul  | ADREGISL  | -                    | ZAZH          |        |          |       |       |                 |                                                                                                       |                                                                                                                           |                       |  |  |
| ADREG15H register 1/5 high                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |           |                      |               |        |          | 10047 | 10010 | 10045           | 10011                                                                                                 | 40040                                                                                                                     |                       |  |  |
| AD result register 2/6 low                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | ADDEC15U  |                      | 2421          | ADR19  | ADR18    | ADR17 | L     |                 | ADR14                                                                                                 | ADR13                                                                                                                     | ADR12                 |  |  |
| ADREG26L register 2/6 low 2A4H 2A4H 2A4H 2A5H 2A6H ADR29 ADR28 ADR27 ADR26 ADR25 ADR24 ADR23 ADR22  AD result register 2/6 high AD result register 3/7 low AD result register 3/7 low AD result register 2A7H ADR26 ADR27 ADR26 ADR25 ADR24 ADR23 ADR22 ADR28 ADR27 ADR26 ADR25 ADR24 ADR23 ADR22 ADR26 ADR26 ADR26 ADR26 ADR27 ADR26 ADR27 ADR26 ADR27 ADR26 ADR27 ADR26 ADR27 ADR36 ADR37 ADR38 ADR37 ADR36 ADR37 ADR36 ADR37 ADR38 ADR37 ADR36 ADR37 ADR38 ADR37 ADR36 ADR37 ADR36 ADR37 ADR38 ADR37 ADR36 ADR37 ADR36 ADR37 ADR38 ADR37 ADR36 ADR37 ADR38 ADR37 ADR36 ADR37 ADR38 ADR37 ADR38 ADR37 ADR36 ADR37 ADR38 ADR37 ADR36 ADR37 ADR38 ADR37 ADR36 ADR37 ADR38 ADR38 ADR37 ADR38 ADR38 ADR37 ADR38 ADR3 | ADREGION  |                      | ZASH          |        |          |       |       |                 |                                                                                                       |                                                                                                                           |                       |  |  |
| ADREG26L register 2/6 low                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |           | _                    |               | ADD04  | ADDOO    |       | Unde  | milea           |                                                                                                       |                                                                                                                           | ADBODE                |  |  |
| AD result register 2/6 high   AD result register 3/7 low   AD result register 3/7 low   AD result register 2ATH   AD result register 3/7 low   AD result register 2ATH   AD result register 3/7 low   AD result register 2ATH   ADR39   ADR38   ADR37   ADR36   ADR35   ADR34   ADR33   ADR32   ADR36   ADR35   ADR34   ADR33   ADR32   ADR36   ADR36   ADR35   ADR34   ADR33   ADR32   ADR36   ADR36   ADR36   ADR36   ADR36   ADR36   ADR37   ADR36   ADR36   ADR36   ADR37   ADR36   ADR36   ADR37   ADR37   ADR36   AD    | ADREGOEL  |                      | 2∆1⊔          |        |          |       |       |                 |                                                                                                       |                                                                                                                           | <b>-</b>              |  |  |
| AD result register 2/6 high                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | ADREGZOL  | -                    | 2/411         |        |          |       |       |                 |                                                                                                       |                                                                                                                           |                       |  |  |
| ADREG26H register 2/6 high                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |           |                      |               |        |          | ADD07 | ADDOG | ADDOE           | ADD24                                                                                                 | ADDOS                                                                                                                     |                       |  |  |
| 2/6 high       Undefined         AD result register 3/7 low       2A6H       ADR31       ADR30       ADR3R       ADR3R       ADR3R       R       R       R       R       R       Q       ADR3R       ADR3R       ADR3F       ADR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | ∆DREG26⊔  |                      | 2 <b>45</b> H | ADKZ9  | AUKZ8    | ADK2/ |       | 1               | AUK24                                                                                                 | ADK23                                                                                                                     | AUKZZ                 |  |  |
| ADREG37L register 3/7 low                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | ADREGZOIT |                      | ZAJII         |        |          |       |       |                 |                                                                                                       |                                                                                                                           |                       |  |  |
| ADREG37L register 3/7 low                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |           | AD result            |               | ADR31  | ADR30    |       |       |                 |                                                                                                       |                                                                                                                           | ADR3RF                |  |  |
| AD result register 2A7H                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | ADREG37L  | register             | 2A6H          |        |          |       |       |                 |                                                                                                       |                                                                                                                           |                       |  |  |
| ADREG37H register 2A7H R                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |           | 3/7 low              |               | Unde   | efined   |       |       |                 |                                                                                                       |                                                                                                                           | 0                     |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |           |                      |               | ADR39  | ADR38    | ADR37 |       |                 | ADR34                                                                                                 | ADR33                                                                                                                     | ADR32                 |  |  |
| - Lindelined                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | ADREG37H  | register<br>3/7 high | 2A7H          |        |          |       |       |                 |                                                                                                       |                                                                                                                           |                       |  |  |

## (11) Watchdog timer

| Symbol | Name                    | Address                   | 7                | 6                                                                                                                                                                | 5      | 4                    | 3                      | 2                               | 1                                                | 0                    |
|--------|-------------------------|---------------------------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|----------------------|------------------------|---------------------------------|--------------------------------------------------|----------------------|
|        |                         |                           | WDTE             | WDTP1                                                                                                                                                            | WDTP0  |                      |                        | I2WDT                           | RESCR                                            | -                    |
|        |                         |                           | R/W              | R/W                                                                                                                                                              | R/W    |                      |                        | R/W                             | R/W                                              | R/W                  |
|        |                         |                           | 1                | 0                                                                                                                                                                | 0      |                      |                        | 0                               | 0                                                | 0                    |
| WDMOD  | WDT<br>mode<br>register | 300H                      | 1: WDT<br>enable | 00: 2 <sup>15</sup> /f <sub>SYS</sub><br>01: 2 <sup>17</sup> /f <sub>SYS</sub><br>10: 2 <sup>19</sup> /f <sub>SYS</sub><br>11: 2 <sup>21</sup> /f <sub>SYS</sub> |        |                      |                        | IDLE2<br>0: Abort<br>1: Operate | 1: RESET connect internally WDT out to reset pin | Always<br>write "0". |
| WDCR   | WD<br>control           | 301H<br>(Prohibit<br>RMW) |                  |                                                                                                                                                                  | B1H: W | V<br>-<br>DT disable | -<br>V<br>-<br>4EH: WI | DT clear                        |                                                  |                      |

### (12) RTC (Real time clock)

| Symbol   | Name      | Address           | 7            | 6            | 5                  | 4            | 3          | 2          | 1          | 0                   |
|----------|-----------|-------------------|--------------|--------------|--------------------|--------------|------------|------------|------------|---------------------|
| Syllibol | TAGITIC   | , (001000         |              | SE6          | SE5                | SE4          | SE3        | SE2        | SE1        | SE0                 |
|          | Second    |                   | //           | 020          | 020                | 021          | R/W        | OLL        | 021        | 020                 |
| SECR     | register  | 320H              | $\bigg $     |              |                    |              | Undefined  |            |            |                     |
|          |           |                   | "0" is read. | 40 sec       | 20 sec             | 10 sec       | 8 sec      | 4 sec      | 2 sec      | 1 sec               |
|          |           |                   |              | MI6          | MI5                | MI4          | MI3        | MI2        | MI1        | MIO                 |
|          | Minute    |                   | //           |              | I                  | I            | R/W        |            |            |                     |
| MINR     | register  | 321H              | //           |              |                    |              | Undefined  |            |            |                     |
|          |           |                   | "0" is read. | 40 min       | 20 min             | 10 min       | 8 min      | 4 min      | 2 min      | 1min                |
|          |           |                   |              |              | HO5                | HO4          | HO3        | HO2        | HO1        | HO0                 |
|          | Hour      |                   |              |              |                    | •            | R/         | W          |            |                     |
| HOURR    | register  | 322H              |              |              |                    |              | Unde       | efined     |            |                     |
|          | . eg.e.e. |                   | "0" is       | read.        | 20 hour<br>(PM/AM) | 10 hour      | 8 hour     | 4 hour     | 2 hour     | 1 hour              |
|          |           |                   |              |              |                    |              |            | WE2        | WE1        | WE0                 |
| DAYR     | Day       | 323H              |              |              |                    |              |            |            | R/W        |                     |
| 5/(11)   | register  | 32011             |              |              |                    |              |            |            | Undefined  | ·                   |
|          |           |                   |              |              | "0" is read.       |              |            | W2         | W1         | W0                  |
|          |           |                   |              |              | DA5                | DA4          | DA3        | DA2        | DA1        | DA0                 |
| DATER    | Date      | 324H              |              |              |                    |              |            | W          |            |                     |
|          | register  |                   |              |              |                    | i            | Unde       |            |            | i                   |
|          |           |                   | 0            | 0            | Day 20             | Day 10       | Day 8      | Day 4      | Day 2      | Day 1               |
|          |           |                   |              |              |                    | MO4          | MO3        | MO2        | MO1        | MO0                 |
|          |           | 325H              |              |              |                    |              |            | R/W        |            |                     |
|          |           | PAGE0             |              | "0" is read. |                    | 40           | 0          | Undefined  | 0          | 4 41-               |
| MONTHR   | Month     | PAGE0             |              | U is read.   |                    | 10 month     | 8 month    | 4 month    | 2 month    | 1 month             |
| MONTHK   | register  | PAGET             |              |              |                    | "0" is read. |            |            |            | 0: Indicator for 12 |
|          |           |                   |              |              |                    |              |            |            |            | hours               |
|          |           |                   |              |              |                    |              |            |            |            | 1: Indicator        |
|          |           |                   |              |              |                    |              |            |            |            | for 24<br>hours     |
|          |           |                   | YE7          | YE6          | YE5                | YE4          | YE3        | YE2        | YE1        | YE0                 |
|          |           | 326H              |              | 1            | 10                 |              | /W         | 1          |            | 1 3                 |
| YEARR    | Year      |                   |              |              |                    |              | efined     |            |            |                     |
|          | register  | PAGE0             | 80 year      | 40 year      | 20 year            | 10 year      | 8 year     | 4 year     | 2 year     | 1 year              |
|          |           | PAGE1             |              |              | "0" is             | read.        |            |            | Leap year  | ar setting          |
|          |           |                   | INTENA       |              |                    | ADJUST       | ENATMR     | ENAALM     |            | PAGE                |
|          |           |                   | R/W          |              |                    | W            | R/         | W          |            | R/W                 |
|          | Page      | 327H              | 0            |              |                    | Undefined    | Unde       | efined     |            | Undefined           |
| PAGER    | register  | (Prohibit         | INTRTC       | "0" is       | read.              | 0: Don't     | Clock      | ALARM      | "0" is     | PAGE                |
|          | -3.2.0    | RMW)              | 0: Disable   |              |                    | care         | 0: Disable | 0: Disable | read.      | setting             |
|          |           |                   | 1: Enable    |              |                    | 1: Adjust    | 1: Enable  | 1: Enable  |            |                     |
|          |           |                   | DIS1HZ       | DIS16HZ      | RSTTMR             | RSTALM       | RE3        | RE2        | RE1        | RE0                 |
|          |           |                   | DIOTIL       | 21010112     | ACTIVIT            |              | N KES      | 112        | 11.61      | I NEO               |
| DE0==    | Reset     | 328H              |              |              |                    |              | efined     |            |            |                     |
| RESTR    | register  | (Prohibit<br>RMW) | 1 Hz         | 16 Hz        | 1: Clock           | 1: Alarm     |            | Always v   | write "0". |                     |
|          |           | IZIVIVV)          | 0: Disable   | 0: Disable   | reset              | reset        |            | .,,-       | -          |                     |
|          | 1         |                   | 1: Enable    | 1: Enable    |                    |              |            |            |            |                     |

## (13) Melody/alarm generator

| Symbol      | Name                              | Address | 7                                                                             | 6   | 5                                        | 4            | 3                                        | 2           | 1             | 0                                            |
|-------------|-----------------------------------|---------|-------------------------------------------------------------------------------|-----|------------------------------------------|--------------|------------------------------------------|-------------|---------------|----------------------------------------------|
|             |                                   |         | AL8                                                                           | AL7 | AL6                                      | AL5          | AL4                                      | AL3         | AL2           | AL1                                          |
| ALM         | Alarm<br>pattern                  | 330H    |                                                                               |     |                                          | R/           | W                                        |             |               |                                              |
| ALIVI       | register                          | 33011   | 0                                                                             | 0   | 0                                        | 0            | 0                                        | 0           | 0             | 0                                            |
|             |                                   |         |                                                                               |     |                                          | Alarm – P    | attern set                               |             |               |                                              |
|             |                                   |         | FC1                                                                           | FC0 | ALMINV                                   | -            | -                                        | -           | _             | MELALM                                       |
|             |                                   |         | R/                                                                            | W   | R/W                                      |              | R/                                       | W           |               | R/W                                          |
|             | Melody/                           |         | 0                                                                             | 0   | 0                                        | 0            | 0                                        | 0           | 0             | 0                                            |
| MEL<br>ALMC | alarm<br>control<br>register      | 331H    | Free-run co<br>control<br>00: Hold<br>01: Restart<br>10: Clear<br>11: Clear a |     | Alarm<br>waveform<br>invert<br>1: Invert |              | Always                                   | write "0".  |               | Output<br>frequency<br>0: Alarm<br>1: Melody |
|             |                                   |         | ML7                                                                           | ML6 | ML5                                      | ML4          | ML3                                      | ML2         | ML1           | ML0                                          |
| MELFL       | Melody<br>frequency               | 332H    |                                                                               | _   | _                                        | R/           | W                                        |             |               |                                              |
| IVILLI      | register-L                        | 33211   | 0                                                                             | 0   | 0                                        | 0            | 0                                        | 0           | 0             | 0                                            |
|             |                                   |         |                                                                               |     | Melo                                     | dy frequency | set (Low 8                               | bits)       |               |                                              |
|             |                                   |         | MELON                                                                         |     |                                          |              | ML11                                     | ML10        | ML9           | ML8                                          |
|             |                                   |         | R/W                                                                           |     |                                          |              |                                          | R/          | W             |                                              |
|             |                                   |         | 0                                                                             |     |                                          |              | 0                                        | 0           | 0             | 0                                            |
| MELFH       | Melody<br>frequency<br>register-H | 333H    | Melody<br>counter<br>control<br>0: Stop<br>and<br>clear<br>1: Start           |     |                                          |              | Melo                                     | dy frequenc | y set (High 4 | 4 bits)                                      |
|             |                                   |         |                                                                               |     | -                                        | IALM4E       | IALM3E                                   | IALM2E      | IALM1E        | IALM0E                                       |
|             | Alarm interrupt                   |         |                                                                               |     | R/W                                      |              |                                          | R/W         |               |                                              |
| ALMINT      | enable                            | 334H    |                                                                               |     | 0                                        | 0            | 0                                        | 0           | 0             | 0                                            |
|             | register                          |         |                                                                               |     | Always<br>write "0".                     | INT          | NTALM4 to INTALM0 alarm interrupt enable |             |               | nable                                        |

**TOSHIBA** 

### (14) MMU

| Symbol | Name                | Address | 7                       | 6 | 5 | 4           | 3             | 2            | 1                 | 0      |
|--------|---------------------|---------|-------------------------|---|---|-------------|---------------|--------------|-------------------|--------|
|        |                     |         | L0E                     |   |   |             |               | L0EA22       | L0EA21            | L0EA20 |
|        |                     |         | R/W                     |   |   |             |               |              | R/W               |        |
|        | LOCAL0              |         | 0                       |   |   |             |               |              | 0                 |        |
| LOCAL0 | control<br>register | 350H    | BANK for<br>LOCAL 0     |   |   |             |               | Set BANK r   | number for L      | OCAL0  |
|        |                     |         | 0: Disable<br>1: Enable |   |   |             |               | Do not set " | 000" becaus       | e of   |
|        |                     |         | L1E                     |   |   |             |               | L1EA23       | L1EA22            | L1EA21 |
|        |                     |         | R/W                     |   |   |             |               |              | R/W               | •      |
|        | LOCAL1              |         | 0                       |   |   |             |               | 0            |                   |        |
| LOCAL1 | control<br>register | 351H    | BANK for<br>LOCAL 1     |   |   |             |               | Set BANK r   | number for L      | OCAL1  |
|        |                     |         | 0: Disable<br>1: Enable |   |   |             |               | Do not set " | 001" becaus       | e of   |
|        |                     |         | L2E                     |   |   |             |               | L2EA23       | L2EA22            | L2EA21 |
|        |                     |         | R/W                     |   |   |             |               |              | R/W               | l .    |
|        | LOCAL2              |         | 0                       |   |   |             |               | 0            |                   |        |
| LOCAL2 | control<br>register | 352H    | BANK for<br>LOCAL 2     |   |   |             |               | Set BANK r   | number for L      | OCAL2  |
|        |                     |         | 0: Disable<br>1: Enable |   |   |             |               | Do not set " | 111" becaus<br>ea | e of   |
|        |                     |         | L3E                     |   |   | L3EA26      | L3EA25        | L3EA24       | L3EA23            | L3EA22 |
|        |                     |         | R/W                     |   |   |             | l.            | R/W          |                   | l      |
|        | LOCAL3              |         | 0                       |   |   | 0           | 0             | 0            | 0                 | 0      |
| LOCAL3 | control             | 353H    | BANK for                |   |   | 00000 to 00 | 011 : CS2B    | 0110         | 00 to 01111 :     | CS2E   |
|        | register            |         | LOCAL 3                 |   |   | 00100 to 00 | )111 : CS2C   | 1000         | 0 to 10011 :      | CS2F   |
|        |                     |         | 0: Disable              |   |   | 01000 to 01 | 011: CS2D     | 1010         | 0 to 10111 :      | CS2G   |
|        |                     |         | 1: Enable               |   |   | 11000 to 11 | 111 : Set pro | ohibition    |                   |        |

## (15) LCD controller (1/5)

| Symbol    | Name          | Address | 7          | 6                | 5            | 4                         | 3                     | 2                         | 1                     | 0          |
|-----------|---------------|---------|------------|------------------|--------------|---------------------------|-----------------------|---------------------------|-----------------------|------------|
|           |               |         | BAE        | AAE              | SCPW1        | SCPW0                     | -                     | BULK                      | RAMTYPE               | MODE       |
|           |               |         |            | l .              | l.           | R                         | W                     | l.                        |                       | ı          |
|           |               |         | 0          | 0                | 1            | 0                         | 0                     | 0                         | 0                     | 0          |
| LCDMODE   | LCD<br>mode   | 04B0H   | Used by B  | Used by A        | SCP width    | •                         | Always                | SDRAM                     | Display               | Mode       |
| LODIVIODE | register      | 040011  | AREA       | AREA             | 00: Base m   | ode                       | write "0".            | bank                      | RAM                   | selection  |
|           |               |         | 0: Disable | 0: Disable       | 01: 2 clocks | 5                         |                       | selection                 | Selection             | 0: RAM     |
|           |               |         | 1: Enable  | 1: Enable        | 10: 4 clocks |                           |                       | 0: 64 Mbit<br>1: 128 Mbit | 0: SRAM               | 1: SR      |
|           |               |         |            |                  | 11: 8 clocks |                           |                       | 1. 120 IVIDIL             | I. SDRAW              |            |
|           | Divide        |         | FMN7       | FMN6             | FMN5         | FMN4                      | FMN3                  | FMN2                      | FMN1                  | FMN0       |
| LCDDVM    | Frame         | 04B1    |            | T                | T            | 1                         | /W                    | 1                         | 1                     | 1          |
|           | register      |         | 0          | 0                | 0            | 0                         | 0                     | 0                         | 0                     | 0          |
|           |               |         |            | ı                | _            | 1                         | ljust function        |                           | 1                     | 1          |
|           |               |         | COM3       | COM2             | COM1         | COM0                      | SEG3                  | SEG2                      | SEG1                  | SEG0       |
|           |               |         |            | T .              | 1 .          |                           | /W                    | ı                         | 1                     | 1 .        |
|           |               |         | 0          | 0                | 0            | 0                         | 0                     | 0                         | 0                     | 0          |
|           | LCD           |         | _          | LCD commo        |              | or SR type                | _                     | LCD segme                 |                       | or SR type |
| LCDSIZE   | size          | 04B2H   | 0000: 128  | 0101: 400        |              |                           | 0000: 128             | 0101: 480                 |                       |            |
|           | register      |         | 0001: 160  | 0110: 480        |              |                           | 0001: 160             | 0110: 560                 |                       |            |
|           |               |         | 0010: 200  |                  |              |                           | 0010: 240             | 0111: 640                 |                       |            |
|           |               |         | 0011: 240  |                  |              |                           | 0011: 320             |                           |                       |            |
|           |               |         | 0100: 320  | D                |              |                           | 0100: 400             | D                         |                       |            |
|           |               |         | LCDON      | : Reserve        | FRMON        | 1                         | FP9                   | : Reserve                 | FP8                   | START      |
|           |               |         | LCDON      | ALL0             | FRIVION      |                           |                       | MMULCD                    | FFO                   | START      |
|           |               |         | 0          | 0                | 0            | 0                         | 0                     | 0                         | 0                     | 0          |
|           |               |         | DOFF       | Transfer         | Divided      | Always                    | Setting               | Specify                   | Setting               | Start      |
|           | LCD           |         | port       | data of          | FR mode      | write "0".                | bit9 for              | address                   | bit8 for              | control in |
| LCDCTL    | control       | 04B3H   | 0: OFF     | exclusive        | 0: Disable   |                           | f <sub>FP</sub> [9:0] | of LCD                    | f <sub>FP</sub> [9:0] | SR type    |
|           | register      |         | 1: ON      | bus for          | 1: Enable    |                           |                       | driver with               |                       |            |
|           |               |         |            | LCD              |              |                           |                       | built-in<br>RAM           |                       | 0: Stop    |
|           |               |         |            | 0:Normal         |              |                           |                       | 0: OFF                    |                       | 1: Start   |
|           |               |         |            | 1:All<br>display |              |                           |                       | 1: ON                     |                       |            |
|           |               |         |            | data 0           |              |                           |                       | 1. 01                     |                       |            |
|           | LCD           |         | FP7        | FP6              | FP5          | FP4                       | FP3                   | FP2                       | FP1                   | FP0        |
| LCDFFP    | Frame         | 04B4H   |            |                  | •            | R/                        | W                     | •                         |                       |            |
| LCDFFP    | Frequency     | U4D4H   | 0          | 0                | 0            | 0                         | 0                     | 0                         | 0                     | 0          |
|           | Register      |         |            |                  |              | f <sub>FP</sub> set value | e bit7 to bit0        |                           |                       |            |
|           |               |         |            |                  |              |                           |                       |                           | GRAY1                 | GRAY0      |
|           |               |         |            |                  |              |                           |                       |                           | R/W                   | R/W        |
|           | LCD           |         |            |                  |              |                           |                       |                           | 0                     | 0          |
| LCDGL     | gray<br>level | 04B5H   |            |                  |              |                           |                       |                           | 00: Monocl            | nrome      |
|           | register      |         |            |                  |              |                           |                       |                           | 01: 4 levels          | 3          |
|           |               |         |            |                  |              |                           |                       |                           | 10: 8 levels          | 5          |
|           |               |         |            |                  |              |                           |                       |                           | 11: 16 leve           | ls         |

LCD controller (2/5)

| Symbol  | Name                       | Address | 7                         | 6                                       | 5             | 4               | 3                                  | 2               | 1                                                                | 0            |
|---------|----------------------------|---------|---------------------------|-----------------------------------------|---------------|-----------------|------------------------------------|-----------------|------------------------------------------------------------------|--------------|
|         |                            |         | CDE                       | ccs                                     |               |                 |                                    |                 | CBE1                                                             | CBE0         |
|         |                            |         | R                         | /W                                      |               |                 |                                    |                 | R                                                                | W            |
|         | LCD                        |         | 0                         | 0                                       |               |                 |                                    |                 | 0                                                                | 0            |
| LCDCM   | cursor<br>mode<br>register | 04B6H   | Cursor<br>0: OFF<br>1: ON | Cursor<br>color<br>0: White<br>1: Black |               |                 |                                    |                 | Cursor blin<br>00: Don't b<br>01: 2 Hz<br>10: 1 Hz<br>11: 0.5 Hz |              |
|         |                            |         |                           |                                         |               | CW4             | CW3                                | CW2             | CW1                                                              | CW0          |
|         | LCD                        |         | //                        |                                         |               | OW4             | 0110                               | R/W             | 0001                                                             | 0110         |
|         | cursor                     |         | //                        |                                         |               | 0               | 0                                  | 0               | 0                                                                | 0            |
| LCDCW   | width<br>register          | 04B7H   |                           |                                         |               |                 | Curs<br>00000: 1 do<br>11111: 32 d |                 | size)                                                            | -            |
|         |                            |         |                           |                                         |               | CW4             | CW3                                | CW2             | CW1                                                              | CW0          |
|         | LCD                        |         |                           |                                         |               |                 |                                    | R/W             | •                                                                |              |
| LCDCH   | cursor                     | 04B8H   |                           |                                         |               | 0               | 0                                  | 0               | 0                                                                | 0            |
|         | height<br>register         |         |                           |                                         |               |                 | Curs<br>00000: 1 do<br>11111: 32 d |                 | size)                                                            |              |
|         | LCD                        |         |                           |                                         |               |                 | APB 3                              | APB 2           | APB 1                                                            | APB 0        |
| LCDCP   | cursor                     | 04B9H   |                           |                                         |               |                 |                                    | R               | W                                                                |              |
| LODGE   | APB                        | 046911  |                           |                                         |               |                 | 0                                  | 0               | 0                                                                | 0            |
|         | register                   |         |                           |                                         |               |                 | Setting bit3                       | 3 to bit0 for o | cursor absolu                                                    | ıte position |
|         | LCD                        |         | CAP 7                     | CAP 6                                   | CAP 5         | CAP 4           | CAP 3                              | CAP 2           | CAP 1                                                            | CAP 0        |
| LCDCPL  | cursor                     | 04BAH   |                           |                                         |               | R/              | W                                  |                 |                                                                  |              |
| LODOI L | AP                         | OFDAIT  | 0                         | 0                                       | 0             | 0               | 0                                  | 0               | 0                                                                | 0            |
|         | register-L                 |         |                           |                                         | Setting bit   | 7 to bit0 for c | cursor absolu                      | ute position    |                                                                  |              |
|         | LCD                        |         | CAP 15                    | CAP 14                                  | CAP 13        | CAP 12          | CAP 11                             | CAP 10          | CAP 9                                                            | CAP 8        |
| LCDCPM  | cursor                     | 04BBH   |                           |                                         |               | R/              | W                                  |                 |                                                                  |              |
| LODGI W | AP                         | 040011  | 0                         | 0                                       | 0             | 0               | 0                                  | 0               | 0                                                                | 0            |
|         | register-M                 |         |                           |                                         | Setting bit1  | 5 to bit8 for   | cursor absol                       | ute position    |                                                                  |              |
|         | LCD                        |         | CAP 23                    | CAP 22                                  | CAP 21        | CAP 20          | CAP 19                             | CAP 18          | CAP 17                                                           | CAP 16       |
| LCDCPH  | cursor                     | 04BCH   |                           |                                         |               | R               | W                                  |                 |                                                                  |              |
| LODOFI  | AP                         | 045011  | 0                         | 1                                       | 0             | 0               | 0                                  | 0               | 0                                                                | 0            |
|         | register-H                 |         |                           |                                         | Setting bit23 | 3 to bit16 for  | cursor abso                        | lute position   |                                                                  |              |

### LCD controller (3/5)

| Symbol    | Name                  | Address | 7    | 6             | 5           | 4                   | 3            | 2            | 1          | 0    |
|-----------|-----------------------|---------|------|---------------|-------------|---------------------|--------------|--------------|------------|------|
|           |                       |         | SA15 | SA14          | SA13        | SA12                | SA11         | SA10         | SA9        | SA8  |
|           | A area<br>start       |         |      |               | I           | R/                  | /W           |              | l          | ı    |
| LSARAM    | address               | 04C0H   | 0    | 0             | 0           | 0                   | 0            | 0            | 0          | 0    |
|           | register-M            |         |      | Set start     | address A1  | 5 to A8 for th      | ne source da | ta memory i  | n A area.  |      |
|           | A area                |         | SA23 | SA22          | SA21        | SA20                | SA19         | SA18         | SA17       | SA16 |
| LOADALL   | start                 | 0.40411 |      | I             | I .         | R/                  | W            | I            | l          |      |
| LSARAH    | address               | 04C1H   | 0    | 1             | 0           | 0                   | 0            | 0            | 0          | 0    |
|           | register-H            |         |      | Set start     | address A23 | to A16 for t        | he source da | ata memory   | in A area. | •    |
|           | A area                |         | EA15 | EA14          | EA13        | EA12                | EA11         | EA10         | EA9        | EA8  |
| LEARAM    | end                   | 04C2H   |      | •             | •           | R/                  | W            | •            |            |      |
| LEARAIVI  | address               | 04C2H   | 0    | 0             | 0           | 0                   | 0            | 0            | 0          | 0    |
|           | register-M            |         |      | Set end       | address A1  | to A8 for th        | e source da  | ta memory ir | n A area.  |      |
|           | A area                |         | EA23 | EA22          | EA21        | EA20                | EA19         | EA18         | EA17       | EA16 |
| LEARAH    | end                   | 04C3H   |      |               |             | R/                  | W            |              |            |      |
| LLAIVAIT  | address               | 040311  | 0    | 1             | 0           | 0                   | 0            | 0            | 0          | 0    |
|           | register-H            |         |      | Set end a     | address A23 | to A16 for th       | ne source da | ıta memory i | n A area.  |      |
|           | B area                |         | SA15 | SA14          | SA13        | SA12                | SA11         | SA10         | SA9        | SA8  |
| LSARBM    | start                 | 04C4H   |      |               |             | R/                  | W            |              |            |      |
| LOTURDINI | address               | 040411  | 0    | 0             | 0           | 0                   | 0            | 0            | 0          | 0    |
|           | register-M            |         |      | Set start     | address A1  | 5 to A8 for th      | ne source da | ta memory ii | n B area.  |      |
|           | B area                |         | SA23 | SA22          | SA21        | SA20                | SA19         | SA18         | SA17       | SA16 |
| LSARBH    | start                 | 04C5H   |      |               |             | R/                  | /W           |              |            |      |
| 20/11/211 | address               | 010011  | 0    | 1             | 0           | 0                   | 0            | 0            | 0          | 0    |
|           | register-H            |         |      | Set start     | address A23 | to A16 for t        | he source da | ata memory   | in B area. |      |
|           | B area                |         | EA15 | EA14          | EA13        | EA12                | EA11         | EA10         | EA9        | EA8  |
| LEARBM    | end                   | 04C6H   |      | ı             | 1           | R/                  | W            | ı            | 1          |      |
|           | address<br>register-M |         | 0    | 0             | 0           | 0                   | 0            | 0            | 0          | 0    |
|           | register w            |         |      | Set end       |             | to A8 for th        | e source da  |              | n B area.  |      |
|           | B area                |         | EA23 | EA22          | EA21        | EA20                | EA19         | EA18         | EA17       | EA16 |
| LEARBH    | end                   | 04C7H   |      | Γ             | ı           |                     | /W           | Γ            | 1          |      |
|           | address<br>register-H |         | 0    | 1             | 0           | 0                   | 0            | 0            | 0          | 0    |
|           | 109.0.01              |         |      |               |             | to A16 for th       |              |              |            |      |
|           | C area                |         | SA7  | SA6           | SA5         | SA4                 | SA3          | SA2          | SA1        | SA0  |
| LSARCL    | start                 | 04C8H   |      | <u> </u>      | <u> </u>    |                     | /W           | <u> </u>     | 1 -        |      |
|           | address<br>register-L |         | 0    | 0             | 0           | 0                   | 0            | 0            | 0          | 0    |
|           |                       |         | 2115 |               | 1           | to A0 for the       | 1            | ,            |            |      |
|           | C area                |         | SA15 | SA14          | SA13        | SA12                | SA11         | SA10         | SA9        | SA8  |
| LSARCM    | start<br>address      | 04C9H   |      |               |             | 1                   | W .          |              |            |      |
|           | register-M            |         | 0    | 0<br>Cat atom | 0           | 0<br>E to A0 for th | 0            | 0            | 0          | 0    |
|           | , i                   |         | 0400 |               |             | 5 to A8 for th      |              |              |            | 0440 |
|           | C area                |         | SA23 | SA22          | SA21        | SA20                | SA19         | SA18         | SA17       | SA16 |
| LSARCH    | start<br>address      | 04CAH   |      |               |             |                     | W<br>I o     |              |            |      |
|           | register-H            |         | 0    | 1             | 0           | 0                   | 0            | 0            | 0          | 0    |
|           | 3                     |         |      | Set start     | address A23 | to A16 for t        | he source da | ata memory   | ın C area. |      |

LCD controller (4/5)

| Symbol | Name                                            | Address | 7 | 6 | 5 | 4       | 3       | 2 | 1 | 0 |
|--------|-------------------------------------------------|---------|---|---|---|---------|---------|---|---|---|
|        | LCD gray                                        |         |   |   |   |         |         |   |   |   |
| LG0L   | level data<br>setting<br>register-L             | 04D0H   | 0 | 0 | 0 | 0 R/    | W 0     | 0 | 0 | 0 |
| LG0H   | LCD gray<br>level data<br>setting<br>register-H | 04D1H   | 0 | 0 | 0 | R/<br>0 | W 0     | 0 | 0 | 0 |
| LG1L   | LCD gray<br>level data<br>setting<br>register-L | 04D2H   | 0 | 0 | 0 | R/<br>0 | W 0     | 0 | 0 | 0 |
| LG1H   | LCD gray<br>level data<br>setting<br>register-H | 04D3H   | 1 | 0 | 0 | R/<br>0 | W 0     | 0 | 0 | 0 |
| LG2L   | LCD gray<br>level data<br>setting<br>register-L | 04D4H   | 1 | 0 | 0 | R/<br>0 | /W<br>0 | 0 | 0 | 0 |
| LG2H   | LCD gray<br>level data<br>setting<br>register-H | 04D5H   | 1 | 0 | 0 | R/<br>0 | /W<br>0 | 0 | 0 | 0 |
| LG3L   | LCD gray<br>level data<br>setting<br>register-L | 04D6H   | 1 | 0 | 0 | R/<br>0 | W 0     | 0 | 0 | 0 |
| LG3H   | LCD gray<br>level data<br>setting<br>register-H | 04D7H   | 1 | 0 | 0 | R/<br>0 | /W<br>1 | 0 | 0 | 0 |
| LG4L   | LCD gray<br>level data<br>setting<br>register-L | 04D8H   | 1 | 0 | 0 | R/<br>0 | W 1     | 0 | 0 | 0 |
| LG4H   | LCD gray<br>level data<br>setting<br>register-H | 04D9H   | 1 | 0 | 0 | R/<br>0 | W 1     | 0 | 0 | 0 |
| LG5L   | LCD gray<br>level data<br>setting<br>register-L | 04DAH   | 1 | 0 | 0 | R/<br>0 | W 1     | 0 | 1 | 0 |
| LG5H   | LCD gray<br>level data<br>setting<br>register-H | 04DBH   | 1 | 0 | 0 | R/<br>0 | W 1     | 0 | 0 | 0 |
| LG6L   | LCD gray<br>level data<br>setting<br>register-L | 04DCH   | 1 | 0 | 0 | R/<br>0 | W 1     | 0 | 1 | 0 |
| LG6H   | LCD gray<br>level data<br>setting<br>register-H | 04DDH   | 1 | 0 | 0 | R/<br>0 | /W<br>1 | 0 | 1 | 0 |
| LG7L   | LCD gray<br>level data<br>setting<br>register-L | 04DEH   | 1 | 0 | 1 | R/<br>0 | W 1     | 0 | 1 | 0 |
| LG7H   | LCD gray<br>level data<br>setting<br>register-H | 04DFH   | 1 | 0 | 0 | R/<br>0 | /W<br>1 | 0 | 1 | 0 |

LCD controller (5/5)

| Symbol | Name                                            | Address | 7 | 6 | 5 | 4       | 3       | 2 | 1 | 0 |
|--------|-------------------------------------------------|---------|---|---|---|---------|---------|---|---|---|
|        | LCD gray                                        |         |   |   |   | R/      | 00/     |   |   |   |
| LG8L   | level data<br>setting<br>register-L             | 04E0H   | 1 | 0 | 1 | 0       | 1       | 0 | 1 | 0 |
| LG8H   | LCD gray<br>level data<br>setting<br>register-H | 04E1H   | 1 | 0 | 1 | R/<br>0 | /W<br>1 | 0 | 1 | 0 |
| LG9L   | LCD gray<br>level data<br>setting<br>register-L | 04E2H   | 0 | 1 | 0 | R/      | W 0     | 1 | 0 | 1 |
| LG9H   | LCD gray<br>level data<br>setting<br>register-H | 04E3H   | 1 | 1 | 0 | R/      | W 0     | 1 | 0 | 1 |
| LGAL   | LCD gray<br>level data<br>setting<br>register-L | 04E4H   | 1 | 1 | 0 | R/      | W 0     | 1 | 0 | 1 |
| LGAH   | LCD gray<br>level data<br>setting<br>register-H | 04E5H   | 1 | 1 | 0 | R/<br>1 | W 0     | 1 | 0 | 1 |
| LGBL   | LCD gray<br>level data<br>setting<br>register-L | 04E6H   | 1 | 1 | 0 | R/      | W 0     | 1 | 0 | 1 |
| LGBH   | LCD gray<br>level data<br>setting<br>register-H | 04E7H   | 1 | 1 | 0 | R/      | W 1     | 1 | 0 | 1 |
| LGCL   | LCD gray<br>level data<br>setting<br>register-L | 04E8H   | 1 | 1 | 0 | R/      | W 1     | 1 | 0 | 1 |
| LGCH   | LCD gray<br>level data<br>setting<br>register-H | 04E9H   | 1 | 1 | 0 | R/      | W 1     | 1 | 0 | 1 |
| LGDL   | LCD gray<br>level data<br>setting<br>register-L | 04EAH   | 1 | 1 | 0 | R/      | /W 1    | 1 | 0 | 1 |
| LGDH   | LCD gray<br>level data<br>setting<br>register-H | 04EBH   | 1 | 1 | 1 | R/      | W 1     | 1 | 0 | 1 |
| LGEL   | LCD gray<br>level data<br>setting<br>register-L | 04ECH   | 1 | 1 | 0 | R/      | /W      | 1 | 0 | 1 |
| LGEH   | LCD gray<br>level data<br>setting<br>register-H | 04EDH   | 1 | 1 | 0 | R/      | /W<br>1 | 1 | 0 | 1 |
| LGFL   | LCD gray<br>level data<br>setting<br>register-L | 04EEH   | 1 | 1 | 1 | R/      | W 1     | 1 | 1 | 1 |
| LGFH   | LCD gray<br>level data<br>setting<br>register-H | 04EFH   | 1 | 1 | 1 | R/      | W 1     | 1 | 1 | 1 |

### (16) SDRAM controller

| Symbol        | Name               | Address | 7                                          | 6                                     | 5          | 4                                               | 3                    | 2                                         | 1                                          | 0               |
|---------------|--------------------|---------|--------------------------------------------|---------------------------------------|------------|-------------------------------------------------|----------------------|-------------------------------------------|--------------------------------------------|-----------------|
|               |                    |         | SDINI                                      | SWRC                                  | -          | -                                               | SMUXE                | SMUXW1                                    | SMUXW0                                     | SMAC            |
|               |                    |         | R/W                                        | R/W                                   | R/W        | R/W                                             |                      | R/                                        | W                                          |                 |
|               | SDRAM              |         | 0                                          | 0                                     | 1          | 0                                               | 0                    | 0                                         | 0                                          | 0               |
|               | address<br>control |         | Auto<br>initialize                         | Write recovery                        |            |                                                 | Address<br>multiplex | SDRAM select<br>00:16 Mbits 10: 128 Mbits |                                            | Access<br>cycle |
|               |                    |         | 0: Disable                                 |                                       | 0: 1 clock |                                                 | 0: Disable           | 01: 64 Mbits                              | 11: Reserved                               | 0: Disable      |
|               |                    |         | 1: Enable                                  | 1: 2 clocks                           |            |                                                 | 1: Enable            |                                           |                                            | 1: Enable       |
|               |                    |         | SFRC                                       | SRS2                                  | SRS1       | SRS0                                            | SASFRC               |                                           |                                            | SRC             |
|               |                    |         |                                            | _                                     | R/W        |                                                 |                      |                                           |                                            | R/W             |
|               | CDDAM              |         | 0                                          | 0                                     | 0          | 0                                               | 0                    |                                           |                                            | 0               |
| SDRCR refresh | refresh<br>control |         | Self<br>refresh<br>0: Disable<br>1: Enable | Auto refresh interval  000: 78 states |            | Auto self<br>refresh<br>0: Disable<br>1: Enable |                      |                                           | Auto<br>refresh<br>0: Disable<br>1: Enable |                 |

### (17) 16-bit timer

| Symbol                                    | Name                                    | Address                   | 7                                           | 6                    | 5                                  | 4                                                            | 3                                                                    | 2                                                                    | 1                                                           | 0          |
|-------------------------------------------|-----------------------------------------|---------------------------|---------------------------------------------|----------------------|------------------------------------|--------------------------------------------------------------|----------------------------------------------------------------------|----------------------------------------------------------------------|-------------------------------------------------------------|------------|
| Cyllibol                                  | Name                                    | Addicas                   | TB0RDE                                      | _                    | <u> </u>                           |                                                              | I2TB0                                                                | TB0PRUN                                                              |                                                             | TB0RUN     |
|                                           |                                         |                           | R/W                                         | R/W                  |                                    |                                                              | R/W                                                                  | R/W                                                                  |                                                             | R/W        |
|                                           | 16-bit                                  |                           | 0                                           | 0                    |                                    |                                                              | 0                                                                    | 0                                                                    |                                                             | 0          |
| TB0RUN                                    | Timer<br>control<br>register            | 180H                      | Double<br>buffer<br>0: Disable<br>1: Enable | Always<br>write "0". |                                    |                                                              | IDLE2<br>0: Stop<br>1: Operate                                       |                                                                      |                                                             |            |
|                                           |                                         |                           | _                                           | _                    | TB0CPOI                            | _                                                            | _                                                                    | TB0CLE                                                               | TB0CLK1                                                     | TB0CLK0    |
|                                           |                                         |                           | R/                                          | W                    | W*                                 |                                                              | <u>I</u>                                                             | R/W                                                                  | 1                                                           |            |
|                                           | 16-bit                                  |                           | 0                                           | 0                    | 1                                  | 0                                                            | 0                                                                    | 0                                                                    | 0                                                           | 0          |
| TB0MOD timer source CLK and mode register | source<br>CLK<br>and<br>mode            | 182H<br>(Prohibit<br>RMW) | Always writ                                 | e "00".              | 0: Soft<br>capture<br>1: Undefined | Always wri                                                   |                                                                      | 1: UC0<br>clear<br>enable                                            | Source clor<br>00: Reserv<br>01: φT1<br>10: φT4<br>11: φT16 | ck         |
|                                           |                                         |                           | -                                           | _                    | -                                  | TB0C0T1                                                      | TB0E1T1                                                              | TB0E0T1                                                              | TB0FF0C1                                                    | TB0FF0C0   |
|                                           |                                         |                           | V                                           | V                    |                                    | R                                                            | /W                                                                   | -                                                                    | V                                                           | /*         |
|                                           |                                         |                           | 1                                           | 1                    | 0                                  | 0                                                            | 0                                                                    | 0                                                                    | 0                                                           | 0          |
| TB0FFCR                                   | 16-bit<br>timer<br>flip-flop<br>control | 183H<br>(Prohibit<br>RMW) | Always write "11".                          |                      | Always<br>write "0".               | TB0FF0 in 0: Trigger of 1: Trigger of                        | disable<br>enable                                                    | I                                                                    | 00: Invert TB0FF0<br>01: Set<br>10: Clear<br>11: Don't care |            |
|                                           | register                                |                           |                                             |                      |                                    | Invert when<br>the UC<br>value is<br>loaded in to<br>TB0CP0. | Invert when<br>the UC<br>value<br>matches<br>the value in<br>TB0RG1. | Invert when<br>the UC<br>value<br>matches<br>the value in<br>TB0RG0. | Always rea                                                  | d as "11". |
|                                           | 16-bit                                  | 188H                      |                                             |                      |                                    |                                                              | _                                                                    |                                                                      |                                                             |            |
| TB0RG0L                                   | timer<br>register<br>0-L                | (Prohibit<br>RMW)         | W<br>Undefined                              |                      |                                    |                                                              |                                                                      |                                                                      |                                                             |            |
| TB0RG0H                                   | 16-bit<br>timer<br>register<br>0-H      | 189H<br>(Prohibit<br>RMW) |                                             |                      |                                    |                                                              | -<br>W<br>efined                                                     |                                                                      |                                                             |            |
|                                           | 16-bit                                  | 1014                      |                                             |                      |                                    |                                                              | _                                                                    |                                                                      |                                                             |            |
| TB0RG1L                                   | timer                                   | 18AH<br>(Prohibit         |                                             |                      |                                    |                                                              |                                                                      |                                                                      |                                                             |            |
|                                           | register<br>1-L                         | RMW)                      |                                             |                      |                                    | Unde                                                         | efined                                                               |                                                                      |                                                             |            |
|                                           | 16-bit<br>timer                         | 18BH                      |                                             |                      |                                    | -                                                            |                                                                      |                                                                      |                                                             |            |
| TB0RG1H                                   | register<br>1-H                         | (Prohibit<br>RMW)         |                                             |                      |                                    | W<br>Undefined                                               |                                                                      |                                                                      |                                                             |            |
|                                           | Capture                                 |                           |                                             |                      |                                    |                                                              | _                                                                    |                                                                      |                                                             |            |
| TB0CP0L                                   | register<br>0-L                         | 18CH                      | R<br>Undefined                              |                      |                                    |                                                              |                                                                      |                                                                      |                                                             |            |
|                                           |                                         |                           |                                             |                      |                                    | Unde                                                         | zili leu                                                             |                                                                      |                                                             |            |
| ТВ0СР0Н                                   | Capture register                        | 18DH                      |                                             |                      |                                    |                                                              | <br>R                                                                |                                                                      |                                                             |            |
|                                           | 0-H                                     |                           |                                             |                      |                                    |                                                              | efined                                                               |                                                                      |                                                             |            |
|                                           | Capture                                 |                           |                                             |                      |                                    |                                                              | =                                                                    |                                                                      |                                                             |            |
| TB0CP1L                                   | register                                | 18EH                      |                                             |                      |                                    |                                                              | R                                                                    |                                                                      |                                                             |            |
|                                           | 1-L                                     |                           |                                             |                      |                                    | Unde                                                         | efined                                                               |                                                                      |                                                             |            |
|                                           | Capture                                 |                           |                                             |                      |                                    |                                                              | _                                                                    |                                                                      |                                                             |            |
| TB0CP1H                                   | register<br>1-H                         | 18FH                      |                                             |                      |                                    |                                                              | R                                                                    |                                                                      |                                                             |            |
|                                           | 1-11                                    |                           | Undefined                                   |                      |                                    |                                                              |                                                                      |                                                                      |                                                             |            |

TOSHIBA TMP91C820A

### 6. Points of Note and Restrictions

#### (1) Notation

a. The notation for built-in/ I/O registers is as follows register symbol <Bit symbol> (e.g., TA01RUN <TA0RUN> denotes bit TA0RUN of register TA01RUN).

#### b. Read-modify-write instructions

An instruction in which the CPU reads data from memory and writes the data to the same memory location in one instruction.

Example 1: SET 3, (TA01RUN) ... Set bit 3 of TA01RUN.

Example 2: INC 1, (100H) ... Increment the data at 100H.

Examples of read-modify-write instructions on the TLCS-900

Exchange instruction

EX (mem), R

#### Arithmetic operations

| ADD | (mem), R/# | ADC | (mem), R/# |
|-----|------------|-----|------------|
| SUB | (mem), R/# | SBC | (mem), R/# |
| INC | #3. (mem)  | DEC | #3. (mem)  |

#### Logic operations

| AND | (mem), R/# | OR | (mem), R/# |
|-----|------------|----|------------|
| XOR | (mem), R/# |    |            |

#### Bit manipulation operations

| STCF | #3/A, (mem) | RES | #3, (mem) |
|------|-------------|-----|-----------|
| SET  | #3, (mem)   | CHG | #3, (mem) |
| TSET | #3, (mem)   |     |           |

#### Rotate and shift operations

| RLC                  | (mem) | RRC | (mem) |
|----------------------|-------|-----|-------|
| RL                   | (mem) | RR  | (mem) |
| SLA                  | (mem) | SRA | (mem) |
| $\operatorname{SLL}$ | (mem) | SRL | (mem) |
| RLD                  | (mem) | RRD | (mem) |

#### c. fc, fs, fFPH, fSYS and one state

The clock frequency input on X1 and 2 is called fosch. The clock selected by DFMCR0<ACT1:0> is called fc.

The clock selected by SYSCR1<SYSCK> is called fFPH. The clock frequency give by fFPH divided by 2 is called fSYS.

One cycle of fsys is referred to as one state.

TOSHIBA

#### (2) Points of note

#### a. AM0 and AM1 pins

This pin is connected to the V<sub>CC</sub> or the V<sub>SS</sub> pin. Do not alter the level when the pin is active.

#### b. EMU0 and EMU1

Open pins.

#### c. Reserved address areas

The TMP91C820A does not have any reserved areas.

#### d. Warm-up counter

The warm-up counter operates when STOP mode is released, even if the system is using an external oscillator. As a result a time equivalent to the warm-up time elapses between input of the release request and output of the system clock.

#### e. Programmable pull-up resistance

The programmable pull-up resistor can be turned ON/OFF by a program when the ports are set for use as input ports. When the ports are set for use as output ports, they cannot be turned ON/OFF by a program.

The data registers (e.g., P5) are used to turn the pull-up/pull-down resistors ON/OFF. Consequently read-modify-write instructions are prohibited.

#### f. Watchdog timer

The watchdog timer starts operation immediately after a reset is released. When the watchdog timer is not to be used, disable it.

#### g. AD converter

The string resistor between the VREFH and VREFL pins can be cut by a program so as to reduce power consumption. When STOP mode is used, disable the resistor using the program before the HALT instruction is executed.

#### h. CPU (Micro DMA)

Only the "LDC cr, r" and "LDC r, cr" instructions can be used to access the control registers in the CPU (e.g., the transfer source address register (DMASn)).

#### i. Undefined SFR

The value of an undefined bit in an SFR is undefined when read.

#### j. POP SR instruction

Please execute the POP SR instruction during DI condition.

#### k. Releasing the HALT mode by requesting an interruption

Usually, interrupts can release all halt status. However, the interrupts ( $\overline{\text{NMI}}$ , INTO to INT3, INTKEY, INTRTC, INTALM0 to INTALM4) which can release the HALT mode may not be able to do so if they are input during the period CPU is shifting to the HALT mode (for about 5 clocks of fFPH) with IDLE1 or STOP mode (IDLE2 is not applicable to this case). (In this case, an interrupt request is kept on hold internally.)

If another interrupt is generated after it has shifted to the HALT mode completely, halt status can be released without difficulty. The priority of this interrupt is compared with that of the interrupt kept on hold internally, and the interrupt with higher priority is handled first followed by the other interrupt.

TOSHIBA TMP91C820A

# 7. Package Dimensions

### P-LQFP144-1616-0.40C

Unit: mm



